# RTE-IV Assembler # Reference Manual # RTE-IV Assembler Reference Manual ### PRINTING HISTORY The Printing History below identifies the Edition of this Manual and any Updates that are included. Periodically, Update packages are distributed which contain the latest replacement pages and write-in instructions to be merged into the manual, including an updated copy of this Printing History page. To replenish stock, this manual will be reprinted as necessary. Each such reprinting will incorporate all past Updates, however, no new information will be added. Thus, the reprinted copy will be identical in content to prior printings of the same edition with its user-inserted update information. To determine the specific manual edition and update which is compatible with your current software revision code, refer to the appropriate Software Numbering Catalog. | Third EditionJan | 1980 | |--------------------------------------|------| | Change 1 Apr | 1980 | | Reprinted (Change 1 incorporated)Apr | 1980 | ### NOTICE The information contained in this document is subject to change without notice. HEWLETT-PACKARD MAKES NO WARRANTY OF ANY KIND WITH REGARD TO THIS MATERIAL, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE. Hewlett-Packard shall not be liable for errors contained herein or for incidental or consequential damages in connection with the furnishing, performance or use of this material. Hewlett-Packard assumes no responsibility for the use or reliability of its software on equipment that is not furnished by Hewlett-Packard. This document contains proprietary information which is protected by copyright. All rights are reserved. No part of this document may be photocopied, reproduced or translated to another program language without the prior written consent of Hewlett-Packard Company. This manual describes the Assembler which is designed to operate under the control of HP 1000 RTE based Operating Systems. This manual assumes that the reader is an experienced assembly language programmer who is familiar with operating systems and computer instruction sets. ### HOW TO USE THIS MANUAL The Assembler is a common program that executes under various HP Operating Systems and under various machine instruction sets. This manual describes the Assembler in its totality. Therefore, the user should keep in mind what operating system he is using and what machine the resulting object code is to execute on. All users should read Section I and II. Section I attempts to guide the user to the proper machine instruction set(s). It also discusses the assembly process in general, program relocation, assembly options, and assembler input and output. Section II describes the source statement format that the Assembler accepts as input. Section III describes all of the available machine instructions. It should be noted that while the Assembler will correctly assemble these instructions, the resulting object code will correctly execute only on the intended hardware. The above situation occurs because various machine's instruction sets are subsets of the total instruction set that the Assembler accepts. The user is encouraged to use the appropriate hardware manual in conjunction with this manual to ensure that the assembly code written will execute on the hardware that it is intended for. See Section I for details. Section IV describes all of the available assembler pseudo instructions. Throughout the manual, gray shaded areas indicate sections that are intended for specific CPU hardware. The intention will be noted in the shaded area. In addition, nine appendices are supplied, as follows: Appendix I | Appendix A | describes the Hewlett-Packard character set. | |------------|---------------------------------------------------------------------------------------------------------------------------| | Appendix B | summarizes all of the available machine and pseudo instructions (including instruction formats). $ \\$ | | Appendix C | presents a one-sentence definition of all available machine and pseudo instructions, arranged alphabetically by mnemonic. | | Appendix D | presents a tabular summary of the binary format of all available machine instructions. | | Appendix E | describes how to run an assembly. | | Appendix F | describes the valid instruction set for the M, E, F and L-SERIES computers. | | Appendix G | lists and describes all of the assembler error messages. | | Appendix H | presents output data formats. | discusses the RTE Cross Reference Table Generator. # **CONTENTS** | INTRODUCING THE ASSEMBLER | Section I | Page | Input/Output, Overflow, and Halt | | |------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------------|--------------|-------------------------------------------|--------| | Assembly Processing 1-1 Extended Arithmetic Unit (EAU) 3-5 | | | | | | Symbolic Addressing | | | | | | Memory Addressing | | | | | | Paging | Symbolic Addressing | $\dots 1-1$ | | | | Indirect Addressing | | | | | | Program Relocation 1-2 | Paging | $\dots 1$ -2 | | | | Program Location Counter 1-2 | | | | | | Source Program 1-2 Power Fail Characteristics 3-11 | | | | | | Assembly Options 1-3 Protected Mode 3-12 Simary Output 1-3 BEM Violation 3-12 Symbol Table 1-3 Dynamic Mapping System Instructions 3-12 HP 1000 Fence Registers 3-18 HP 1000 M. E. F-Series Instruction Replacements 3-18 Section II Page Replacement Formats 3-18 Statement of Characteristics 2-1 Replacements 3-18 Character Set 2-1 Section IV Page Statement Length 2-1 Section IV Page States Symbol 2-1 Assembler Control 4-1 Label Symbol 2-1 Operand Field 2-2 Operand Field 2-2 Program Linkage 4-5 Asterisk 2-2 Program and System Common 4-7 Operand Field 2-2 Advers and Symbol Definition 4-1 Symbolic Terms 2-2 Arrest Advers and Symbol Definition 4-1 Numeric Terms 2-4 RTEL Feaudo Instructions 4-2 | | | Map Segmentation | . 3-11 | | Binary Output | Source Program | $\dots 1$ -2 | Power Fail Characteristics | . 3-11 | | Symbol Table | Assembly Options | 1-3 | Protected Mode | . 3-12 | | List Output | Binary Output | 1-3 | MEM Violation | . 3-12 | | Page Page Replacements 3-18 Replacement | Symbol Table | 1-3 | Dynamic Mapping System Instructions | . 3-12 | | Replacements 3-18 | List Output | 1-6 | HP 1000 Fence Registers | . 3-18 | | Replacements Source Statement of Characteristics 2-1 | | | | | | Replacement Formats Sourage Statement of Characteristics 2-1 Field Delimiters 2-1 Character Set 2-1 Section IV Page Statement Length 2-1 Label Field 2-1 Asterisk 2-2 Object Program Linkage 4-5 Asterisk 2-2 Program and System Common 4-7 Address and Symbol Definition 4-11 Asterisk 2-2 Constant Definition 4-11 Symbolic Terms 2-2 Storage Allocation 4-12 Storage Allocation 4-12 Symbolic Terms 2-2 Storage Allocation 4-13 Statement 4-21 Expression Operators 2-4 Asterisk 2-4 LOD Statement 4-21 Expression Terms 2-4 Assembly Listing Control 4-22 Expression Terms 2-4 Assembly Listing Control 4-22 Absolute Expressions 2-4 Assembly Listing Control 4-22 Arithmetic Subroutine Calls 4-23 Absolute Expressions 2-4 Asterisk 2-4 Asterisk 4-24 Arithmetic Subroutine Calls 4-23 Absolute Expressions 2-4 Arithmetic Subroutine Calls 4-24 Alternate Microcode Reference Instruction 4-24 Alternate Microcode Reference Instruction 4-24 Alternate Microcode Reference Instruction 4-24 Alternate Microcode Reference 3-1 Jump and Increment-Skip 3-1 Add, Load and Store 3-2 Machine Instructions 3-2 Machine Instructions 3-2 Byte Processing 3-3 Jump and Increment-Skip 3-1 Add, Load and Store 3-2 Machine Instructions 3-2 Byte Processing 3-3 Jump and Increment-Skip 3-1 Add, Load and Store 3-2 Byte Processing 3-3 Jump and Increment-Skip 3-3 Jump and Increment-Skip 3-3 Byte Processing 3-3 Jump and Increment-Skip 3-3 Byte Processing 3-3 Jump and Increment-Skip 3-3 Byte Processing 3-3 Jump and Increment-Skip 3-3 Jump and Increment-Skip 3-3 Byte Processing 3-3 Jump and Increment-Skip 3-4 Add, Load and Store 3-4 Add, L | Costion II | D | | . 3-18 | | Statement of Characteristics 2-1 Field Delimiters 2-1 Character Set 2-1 Statement Length 2-1 Section IV Page III | | Page | | | | Replacements 3-15 | | 0.1 | | | | Character Set 2-1 Section IV Page | | | | . 3-19 | | Statement Length | | | | | | Label Field 2-1 Assembler Control 4-1 Label Symbol 2-1 Object Program Linkage 4-5 Asterisk 2-2 Program and System Common 4-7 Opcode Field 2-2 Address and Symbol Definition 4-11 Symbolic Terms 2-2 Storage Allocation 4-18 Numeric Terms 2-4 RTE-L Pseudo Instructions 4-21 Asterisk 2-4 RTE-L Pseudo Instructions 4-21 Expression Operators 2-4 GEN Statement 4-22 Expression Terms 2-4 Assembly Listing Control 4-22 Expression Terms 2-4 Assembly Listing Control 4-22 Absolute and Relocatable Expressions 2-4 Arithmetic Subroutine Calls 4-22 Absolute Expressions 2-4 Arithmetic Subroutine Calls 4-22 Absolute Expressions 2-4 Frample 4-22 Clietar Flag Indicator 2-7 Combining Multiple Mnemonics 4-22 Literals 2-6 Combining Multiple Mnemonics 4-24 Alternate Microcode Reference Instruction 4-24 < | | | | Page | | Label Symbol | | | | | | Asterisk | | | | | | Opcode Field 2-2 Address and Symbol Definition 4-11 Operand Field 2-2 Constant Definition 4-14 Symbolic Terms 2-2 Storage Allocation 4-18 Numeric Terms 2-4 RTE-L Pseudo Instructions 4-21 Asterisk 2-4 LOD Statement 4-21 Expression Operators 2-4 GEN Statement 4-21 Evaluation of Expressions 2-4 Assembly Listing Control 4-22 Absolute and Relocatable Expressions 2-4 Assembly Listing Control 4-23 Absolute Expressions 2-4 Assembly Listing Control 4-23 Absolute and Relocatable Expressions 2-4 Assembly Listing Control 4-23 Absolute Expressions 2-4 Subroutine Calls 4-23 Absolute Expressions 2-4 Example 4-24 Absolute Expressions 2-4 Example 4-24 Clear Flag Indicator 2-6 Example 4-24 Clear Flag Indicator 2-7 Example 4-24 <td< td=""><td></td><td></td><td></td><td></td></td<> | | | | | | Operand Field 2-2 Constant Definition 4-14 Symbolic Terms 2-2 Storage Allocation 4-18 Numeric Terms 2-4 RTE-L Pseudo Instructions 4-21 Asterisk 2-4 LOD Statement 4-21 Expression Operators 2-4 GEN Statement 4-21 Evaluation of Expressions 2-4 Assembly Listing Control 4-22 Expression Terms 2-4 Arithmetic Subroutine Calls 4-23 Absolute and Relocatable Expressions 2-4 Arithmetic Subroutine Calls 4-23 Absolute Expressions 2-4 Serine User Instruction 4-23 Relocatable Expressions 2-6 Example 4-23 Literals 2-6 Combining Multiple Mnemonics 4-24 Logical III Page Example 4-24 Abternal Microcode Reference Instruction 4-24 Abternal Microcode Reference Instruction 4-24 Example 4-24 Appendix A Page MACHINE INSTRUCTIONS Appendix B Page | | | | | | Symbolic Terms 2-2 Storage Allocation 4-19 Numeric Terms 2-4 RTE-L Pseudo Instructions 4-21 Asterisk 2-4 LOD Statement 4-21 Expression Operators 2-4 ASSEMBLY Listing Control 4-22 Evaluation of Expressions 2-4 Assembly Listing Control 4-23 Absolute and Relocatable Expressions 2-4 Arithmetic Subroutine Calls 4-23 Absolute Expressions 2-4 Procession Instruction 4-23 Relocatable Expressions 2-6 Example 4-23 Literals 2-6 Combining Multiple Mnemonics 4-24 Literals 2-6 Example 4-24 Clear Flag Indicator 2-7 Example 4-24 Machine Instruction 4-24 Alternate Microcode Reference Instruction 4-24 Machine Instruction 4-24 Appendix A Page MACHINE INSTRUCTIONS Appendix A Page Memory Reference 3-1 Appendix A Page More Frocessing < | | | | | | Numeric Terms 2-4 RTE-L Pseudo Instructions 4-21 Asterisk 2-4 LOD Statement 4-21 Expression Operators 2-4 GEN Statement 4-21 Evaluation of Expressions 2-4 Assembly Listing Control 4-22 Expression Terms 2-4 Arithmetic Subroutine Calls 4-23 Absolute and Relocatable Expressions 2-4 Parithmetic Subroutine Calls 4-23 Absolute Expressions 2-4 Parithmetic Subroutine Calls 4-23 Relocatable Expressions 2-4 Parithmetic Subroutine Calls 4-23 Relocatable Expressions 2-4 Parithmetic Subroutine Calls 4-23 Literals 2-6 Example 4-23 Literals 2-6 Combining Multiple Mnemonics 4-24 Logical Flag Indicator 2-7 Defining Constants 4-24 Alternate Microcode Reference Instruction 4-24 Alternate Microcode Reference Instructions 4-24 Alternate Microcode Reference Instructions 4-24 Appendix A Papendix A | | | | | | Asterisk 2-4 LOD Statement 4-21 | | | | | | Expression Operators 2-4 GEN Statement 4-21 Evaluation of Expressions 2-4 Assembly Listing Control 4-22 Expression Terms 2-4 Arithmetic Subroutine Calls 4-23 Absolute and Relocatable Expressions 2-4 Define User Instruction 4-23 Absolute Expressions 2-6 "Jump to Microprogram" 4-23 Relocatable Expressions 2-6 Example 4-24 Literals 2-6 Combining Multiple Mnemonics 4-24 Lidear Flag Indicator 2-7 Example 4-24 Comments Field 2-7 Example 4-24 Section III Page Example 4-24 Memory Reference 3-1 Jump and Increment-Skip 4-24 Add, Load and Store 3-1 Appendix A Page More Processing 3-2 Machine Instructions B-2 Byte Processing 3-2 Memory Reference B-2 Bit Processing 3-3 Jump and Increment-Skip B-2 Bit Processing | | | RTE-L Pseudo Instructions | . 4-21 | | Evaluation of Expressions 2-4 Assembly Listing Control 4-22 Expression Terms 2-4 Arithmetic Subroutine Calls 4-23 Absolute and Relocatable Expressions 2-4 Define User Instruction 4-23 Absolute Expressions 2-4 "Jump to Microprogram" 4-23 Relocatable Expressions 2-6 Example 4-23 Literals 2-6 Combining Multiple Mnemonics 4-24 Literals 2-6 Example 4-24 Clear Flag Indicator 2-7 Defining Constants 4-24 Comments Field 2-7 Example 4-24 Section III Page Example 4-24 Memory Reference 3-1 Jump and Increment-Skip 4-24 Add, Load and Store 3-1 Appendix A Page More Processing 3-2 Memory Reference B-2 Byte Processing 3-2 Memory Reference B-2 Bit Processing 3-3 Jump and Increment-Skip B-2 Begister Reference 3 | | | LOD Statement | . 4-21 | | Expression Terms | | | | | | Absolute and Relocatable Expressions 2-4 Absolute Expressions 2-4 Relocatable Expressions 2-4 "Jump to Microprogram" 4-23 4-23 4-23 4-23 4-23 4-23 4-23 4-23 4-23 4-23 4-23 4-23 4-23 4-23 4-23 4-23 4-23 4-23 4-23 4-23 4-23 4-23 4-23 4-23 4-23 4-23 4-23 4-23 4-23 4-23 4-23 4-23 4-23 4-23 4-23 4-23 4-23 4-23 4-23 4-23 4-23 4-23 4-23 4-23 4-23 4-23 4-23 4-23 4-23 4-23 4-23 4-23 4-23 4-23 4-23 4-23 4-23 4-23 4-23 4-23 4-23 4-23 4-23 4-23 4-23 4-23 4-23 4-23 4-23 4-23 4-23 4-23 4-23 4-23 4-23 4-23 4-23 4-23 4-23 4-23 4-23 4-23 4-23 4-23 4-23 4-23 4-23 4-23 4-23 4-23 4-23 4-23 4-23 4-23 4-23 4-23 4-23 4-23 4-23 4-23 4-23 4-23 4-23 4-23 4-23 4-23 4-23 4-23 4-23 4-23 4-23 4-23 4-23 4-23 4-23 4-23 4-23 4-23 4-23 4-23 4-23 4-23 4-23 4-23 4-23 4-23 4-23 4-23 4-23 4-23 4-23 4-23 4-23 4-23 4-23 4-23 4-23 4-23 4-23 4-23 4-23 4-23 4-23 4-23 4-23 4-23 4-23 4-23 4-23 4-23 4-23 4-23 4-23 4-23 4-23 4-23 4-23 4-23 4-23 4-23 4-23 4-23 4-23 4-23 4-23 4-23 4-23 4-23 4-23 4-23 4-23 4-23 4-23 4-23 4-23 4-23 4-23 4-23 4-23 4-23 4-23 4-23 4-23 4-23 4-23 4-23 4-23 4-23 4-23 4-23 4-23 4-23 4-23 4-23 4-23 4-23 4-23 4-23 4-23 4-23 4-23 4-23 4-23 4-23 4-23 4-23 4-23 4-23 4-23 4-23 4-23 4-23 4-23 4-23 4-23 4-23 4-23 4-23 4-23 4-23 4-23 4-23 4-23 4-23 4-23 4-23 4-23 4-23 4-23 4-23 4-23 4-23 4-23 4-23 4-23 4-23 4-23 4-23 4-23 4-23 4-23 4-23 4-23 4-23 4-23 4-23 4-23 4-23 4-23 4-23 4-23 4-23 4-23 4-23 4-23 4-23 4-23 4-23 4-23 4-23 4-23 4-23 4-23 4-23 4-23 4-23 4-23 4-23 4-23 4-23 4-23 4-23 4-23 4- | | | | | | Absolute Expressions 2-4 "Jump to Microprogram" 4-23 Relocatable Expressions 2-6 Example 4-23 Literals 2-6 Combining Multiple Mnemonics 4-24 Indirect Addressing 2-6 Example 4-24 Clear Flag Indicator 2-7 Defining Constants 4-24 Comments Field 2-7 Example 4-24 Alternate Microcode Reference Instruction 4-24 Alternate Microcode Reference Instruction 4-24 Alternate Microcode Reference Instruction 4-24 Example 4-24 Alternate Microcode Reference Instruction 4-24 Alternate Microcode Reference Instruction 4-24 Appendix A Page HP CHARACTER SET A-1 Appendix B Page Word Processing 3-2 Byte Processing 3-2 Byte Processing 3-2 Byte Processing 3-3 Bregister Reference 3-4 Add, Load and Store 3-2 Byte Processing 3-4 Alter-Skip Group 3-4 <td></td> <td></td> <td></td> <td></td> | | | | | | Relocatable Expressions 2-6 Example 4-23 Literals 2-6 Combining Multiple Mnemonics 4-24 Indirect Addressing 2-6 Example 4-24 Clear Flag Indicator 2-7 Defining Constants 4-24 Comments Field 2-7 Example 4-24 Alternate Microcode Reference Instruction 4-24 Alternate Microcode Reference Instruction 4-24 Alternate Microcode Reference Instruction 4-24 Appendix A Page Memory Reference 3-1 Jump and Increment-Skip 3-1 Appendix A Page HP CHARACTER SET A-1 Appendix B Page SUMMARY OF INSTRUCTIONS Machine Instructions B-2 Byte Processing 3-2 Memory Reference B-2 Bit Processing 3-3 Jump and Increment-Skip B-2 Bright-Rotate Group 3-4 Add, Load and Store B-2 Shift-Rotate Group 3-4 Logical B-2 Alter-Sk | | | Define User Instruction | . 4-23 | | Literals 2-6 Combining Multiple Mnemonics 4-24 Indirect Addressing 2-6 Example 4-24 Clear Flag Indicator 2-7 Defining Constants 4-24 Comments Field 2-7 Example 4-24 Alternate Microcode Reference Instruction 4-24 Alternate Microcode Reference Instruction 4-24 Alternate Microcode Reference Instruction 4-24 Alternate Microcode Reference Instruction 4-24 Alternate Microcode Reference Instruction 4-24 Appendix A Page HP CHARACTER SET A-1 Appendix B Page Logical Operations 3-2 Word Processing 3-2 Byte Processing 3-2 Byte Processing 3-2 Bit Processing 3-3 Register Reference 3-4 Shift-Rotate Group 3-4 Alter-Skip Group 3-4 Word Processing 3-5 Word Processing 3-6 Memory Reference 3-7 <t< td=""><td></td><td></td><td>"Jump to Microprogram"</td><td>. 4-23</td></t<> | | | "Jump to Microprogram" | . 4-23 | | Indirect Addressing | | | Example | . 4-23 | | Clear Flag Indicator 2-7 Defining Constants 4-24 Comments Field 2-7 Example 4-24 Section III Page Example 4-24 MACHINE INSTRUCTIONS Appendix A Page Memory Reference 3-1 Appendix B Page Jump and Increment-Skip 3-1 Appendix B Page Logical Operations 3-2 SUMMARY OF INSTRUCTIONS Page Word Processing 3-2 Machine Instructions B-2 Byte Processing 3-2 Memory Reference B-2 Bit Processing 3-3 Jump and Increment-Skip B-2 Register Reference 3-4 Add, Load and Store B-2 Shift-Rotate Group 3-4 Logical B-2 Alter-Skip Group 3-4 Word Processing B-2 | | | Combining Multiple Mnemonics | . 4-24 | | Comments Field 2-7 Example 4-24 Alternate Microcode Reference Instruction 4-24 Section III Page Example 4-24 MACHINE INSTRUCTIONS Appendix A Page Memory Reference 3-1 HP CHARACTER SET A-1 Jump and Increment-Skip 3-1 Appendix B Page Logical Operations 3-2 SUMMARY OF INSTRUCTIONS SUMMARY OF INSTRUCTIONS Word Processing 3-2 Machine Instructions B-2 Byte Processing 3-2 Memory Reference B-2 Bit Processing 3-3 Jump and Increment-Skip B-2 Begister Reference 3-4 Add, Load and Store B-2 Shift-Rotate Group 3-4 Logical B-2 Alter-Skip Group 3-4 Word Processing B-2 | | | Example | . 4-24 | | Alternate Microcode Reference Instruction 4-24 | | | Defining Constants | . 4-24 | | Section III Page Example 4-24 MACHINE INSTRUCTIONS Appendix A Page Memory Reference 3-1 HP CHARACTER SET A-1 Jump and Increment-Skip 3-1 Appendix B Page Logical Operations 3-2 SUMMARY OF INSTRUCTIONS B-2 Word Processing 3-2 Machine Instructions B-2 Byte Processing 3-3 Jump and Increment-Skip B-2 Bit Processing 3-3 Jump and Increment-Skip B-2 Register Reference 3-4 Add, Load and Store B-2 Shift-Rotate Group 3-4 Logical B-2 Alter-Skip Group 3-4 Word Processing B-2 | Comments Field | $\dots 2$ -7 | Example | . 4-24 | | MACHINE INSTRUCTIONS Appendix A Page Memory Reference 3-1 Appendix A Page Jump and Increment-Skip 3-1 Appendix B Page Add, Load and Store 3-1 Appendix B Page Logical Operations 3-2 SUMMARY OF INSTRUCTIONS Word Processing 3-2 Machine Instructions B-2 Byte Processing 3-2 Memory Reference B-2 Bit Processing 3-3 Jump and Increment-Skip B-2 Register Reference 3-4 Add, Load and Store B-2 Shift-Rotate Group 3-4 Logical B-2 Alter-Skip Group 3-4 Word Processing B-2 | | | Alternate Microcode Reference Instruction | . 4-24 | | MACHINE INSTRUCTIONS Appendix A Page Memory Reference 3-1 HP CHARACTER SET A-1 Jump and Increment-Skip 3-1 Appendix B Page Add, Load and Store 3-1 Appendix B Page Logical Operations 3-2 SUMMARY OF INSTRUCTIONS Word Processing 3-2 Machine Instructions B-2 Byte Processing 3-2 Memory Reference B-2 Bit Processing 3-3 Jump and Increment-Skip B-2 Register Reference 3-4 Add, Load and Store B-2 Shift-Rotate Group 3-4 Logical B-2 Alter-Skip Group 3-4 Word Processing B-2 | Section III | Page | Example | . 4-24 | | Memory Reference 3-1 Important N 1 age Jump and Increment-Skip 3-1 APPENDATE SET A-1 Add, Load and Store 3-1 Appendix B Page Logical Operations 3-2 SUMMARY OF INSTRUCTIONS Word Processing 3-2 Machine Instructions B-2 Byte Processing 3-2 Memory Reference B-2 Bit Processing 3-3 Jump and Increment-Skip B-2 Register Reference 3-4 Add, Load and Store B-2 Shift-Rotate Group 3-4 Logical B-2 Alter-Skip Group 3-4 Word Processing B-2 | | 1 ago | A A A | D | | Jump and Increment-Skip 3-1 Add, Load and Store 3-1 Logical Operations 3-2 Word Processing 3-2 Byte Processing 3-2 Bit Processing 3-3 Register Reference 3-4 Shift-Rotate Group 3-4 Alter-Skip Group 3-4 Word Processing 3-2 Word Processing 3-3 Jump and Increment-Skip 3-2 Add, Load and Store 3-2 Logical 3-2 Word Processing 3-3 | | 3-1 | | | | Add, Load and Store3-1Appendix BPageLogical Operations3-2SUMMARY OF INSTRUCTIONSWord Processing3-2Machine InstructionsB-2Byte Processing3-2Memory ReferenceB-2Bit Processing3-3Jump and Increment-SkipB-2Register Reference3-4Add, Load and StoreB-2Shift-Rotate Group3-4LogicalB-2Alter-Skip Group3-4Word ProcessingB-2 | | | HF CHARACTER SET | A-1 | | Logical Operations 3-2 SUMMARY OF INSTRUCTIONS Word Processing 3-2 Machine Instructions B-2 Byte Processing 3-2 Memory Reference B-2 Bit Processing 3-3 Jump and Increment-Skip B-2 Register Reference 3-4 Add, Load and Store B-2 Shift-Rotate Group 3-4 Logical B-2 Alter-Skip Group 3-4 Word Processing B-2 | | | Appendix B | Page | | Word Processing 3-2 Machine Instructions B-2 Byte Processing 3-2 Memory Reference B-2 Bit Processing 3-3 Jump and Increment-Skip B-2 Register Reference 3-4 Add, Load and Store B-2 Shift-Rotate Group 3-4 Logical B-2 Alter-Skip Group 3-4 Word Processing B-2 | | | | 8- | | Byte Processing 3-2 Memory Reference B-2 Bit Processing 3-3 Jump and Increment-Skip B-2 Register Reference 3-4 Add, Load and Store B-2 Shift-Rotate Group 3-4 Logical B-2 Alter-Skip Group 3-4 Word Processing B-2 | <del>-</del> - | | | B-2 | | Bit Processing3-3Jump and Increment-SkipB-2Register Reference3-4Add, Load and StoreB-2Shift-Rotate Group3-4LogicalB-2Alter-Skip Group3-4Word ProcessingB-2 | • | | | | | Register Reference 3-4 Add, Load and Store B-2 Shift-Rotate Group 3-4 Logical B-2 Alter-Skip Group 3-4 Word Processing B-2 | | | | | | Shift-Rotate Group 3-4 Logical B-2 Alter-Skip Group 3-4 Word Processing B-2 | | | | | | Alter-Skip Group | | | | | | | | | | | | | Index Register Group | | Byte Processing | | | No-Operation Instruction | | | | | # **CONTENTS** (continued) | | To the state of th | |--------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | Register Reference B-3 | Appendix F Page | | Shift-Rotate B-3 | MACHINE INSTRUCTION SET SUMMARY F-1 | | No-Operation B-4 | | | Alter-Skip B-4 | Appendix G Page | | Index Register B-5 | ASSEMBLER ERROR MESSAGES G-1 | | Input/Output, Overflow, and Halt B-6 | | | Input/Output | Appendix H Page | | Overflow | TAPE FORMATS | | Halt | NAM Record H-1 | | Extended Arithmetic Unit B-6 | ENT Record | | Floating Point B-7 | EXT Record | | Memory ExpansionB-7 | DDI David H-4 | | Pseudo Instructions | DBL Record H-4 | | Assembler Control B-9 | END Record H-5 EMA Record H-5 | | Object Program Linkage B-9 | LOADR/GENERATOR Information Record | | Address and Symbol Definition B-9 | Absolute Format | | Constant Definition B-10 | Absolute Format | | Storage Allocation B-10 | | | Assembly Listing ControlB-10 | Appendix I Page | | Define User Instruction B-10 | RTE CROSS REFERENCE TABLE GENERATOR | | A 1' C | Computer Configuration I-1 | | Appendix C Page | Functional and Operational Characteristics I-1 | | ALPHABETIC LIST OF INSTRUCTIONS C-1 | Output Format | | A 1' D | Pseudo Processing | | Appendix D Page | Double Defined Processing | | CONSOLIDATED CODING SHEETS D-1 | Undefined Label Processing | | A P B | Unused Label Processing | | Appendix E Page | Literal Processing | | RUNNING ASSEMBLIES | Operation Directive | | On-Line Loading of the Assembler E-1 | Bounds | | Assembler Operation E-1 | Sample Cross-Reference Generation | | Messages During Assembly E-3 | Dample Cross-neterence Generation | # **ILLUSTRATIONS** | Title Page | Title Pa | age | |----------------------------------------|---------------------------------------------|-----| | Source Program1-4 | ENT, ENT for I/O Channel | 4-9 | | Symbol Table Listing1-6 | Label RPL Octal Value 4 | | | Label Examples | DEF Examples 4 | | | Label Usage Examples | Example of Incorrect Address Modification 4 | | | Symbolic Operand Examples2-5 | Loader-Assigned Locations for Figure 4-3 4 | | | Expression Operator Examples | Example of Correct Address | | | Indirect Addressing Example2-7 | Modification 4 | -12 | | Clear Flag Examples | Loader-Assigned Locations for Figure 4-15 4 | | | Basic Memory Addressing Scheme 3-10 | ABS Examples 4 | | | Expanded Memory Addressing Scheme 3-11 | EQU Example 4 | | | Map Segmentation | EQU Examples 4 | | | HP 1000 M, E, F-Series Instruction | ASC Example 4 | | | Replacement Formats | DEC Examples (Integer) 4 | | | ORB Example 4-2 | DEC Examples (Floating Point) 4 | | | ORR Example (with Single ORG) 4-3 | DEC Examples (Floating Point)4 | | | ORR Example (with Multiple ORG's) | DEX Memory Format 4 | -17 | | IFN/XIF and IFZ/XIF Example 4-4 | DEX Examples 4 | | | IFZ/XIF Example4-4 | OCT Examples4 | | | COM Examples | BYT Examples4 | | | ENT/EXT Examples 4-8 | EMA Logical Memory for Example | | | EXT with Offset 4-8 | Program 4 | -20 | | ENT in COMmon and ENT Defining an | LOD Pseudo-Instruction Example 4 | | | External I/O Reference | GEN Examples | | # **TABLES** | Title P | age | Title | Page | |--------------------------------|-------|--------------------------------------|------| | Logical Memory Addresses/Pages | | Base Set Instruction Codes in Binary | D-2 | | Control Statement Parameters | . 1-5 | Extended Instruction Group Codes | | | MEM Status Register Format | 3-11 | in Binary | D-3 | | MEM Violation Register Format | 3-11 | XREF Messages | I-3 | ### יווני ### INTRODUCING THE ASSEMBLER The Assembler permits the programmer to use all supported machine instructions for HP 1000 Computers and it is assumed that object programs produced by the Assembler will be executed on an HP 1000 Computer. The Assembler translates symbolic source language instructions into an object program for execution on the computer. The source language provides mnemonic machine operation codes, assembler-directing pseudo instructions, and symbolic addressing. The assembled program may be absolute or relocatable. The source program may be assembled as a complete entity or it may be subdivided into several relocatable subprograms (or a main program and several subroutines), each of which may be assembled separately. When relocatable object programs and subprograms are desired to be executed, they are relocated and linked to one another by the relocating loader. Absolute object programs may be loaded by the Bootstrap Loader. There are no intermediate steps needed to prepare the code before it is executed. The Assembler can read the source input from a disc file or an input device. The Assembler outputs the resultant relocatable or absolute object program to a disc file or an output device. If the object programs produced by the Assembler are relocated and executed under control of an operating system other than the RTE Operating System, the following restrictions apply: ENT pseudo instructions with absolute or common symbols as operands must not be used. I/O instructions using externally-defined select codes must not be used. I/O select codes must not be defined via the ENT pseudo instruction. Memory reference instructions must *not* refer to *exter-nal* symbols with *offset* values. ### 1-1. HP 1000 L-SERIES SYSTEMS The L-SERIES instruction set is a subset of the HP 1000 instruction set. If the programmer is using L-SERIES hardware and its associated operating system, refer him to Appendix F and the HP 1000 L-SERIES REFERENCE MANUAL for a guide to the valid instruction set. The particular features of using the Assembler on an L-SERIES system are documented throughout this manual. The Assembler will correctly assemble any HP 1000 machine instruction. Therefore it is important that the user of an L-SERIES computer refer to the above Appendix and manual so that the proper instruction set is used for assembly programs destined to be executed on L-SERIES hardware. ### 1-2. ASSEMBLY PROCESSING The Assembler is a two pass system. A pass is defined as a processing cycle of the source program input. In the first pass, the Assembler creates a symbol table from the names used in the source statements and (if requested) prints a symbol table listing on the standard list output device. It also checks for certain possible error conditions and prints error messages on the console device if necessary. During pass two, the Assembler again examines each statement in the source program along with the symbol table and produces the binary object program. It outputs the object program to an output device or a disc file. If requested, the Assembler also outputs the source program listing to a list output device or a list file. Additional error messages may also be printed on the system console device. If the source input is being read from a non-disc device, it is written on the disc at the start of pass 1; for pass 2, the source is then read from the disc. However, if there is not sufficient space available on the disc to do this, the Assembler will be suspended until enough disc space is available. ### 1-3. SYMBOLIC ADDRESSING Symbols may be used for referring to machine instructions, data, constants, and certain other pseudo operations. A symbol represents the address for a computer word in memory. A symbol is defined when it is used as a label for a location in the program, a name of a common storage segment, the label of a data storage area or constant, the label of an absolute or relocatable value, or a location external to the program. Through use of simple arithmetic operators, symbols may be combined with other symbols or numbers to form an expression which may identify a location other than that specifically named by a symbol. Symbols appearing in operand expressions, but not specifically defined, and symbols that are defined more than once are considered to be an error by the Assembler. ### 1-4. MEMORY ADDRESSING ### 1-5. PAGING The computer memory is logically divided into pages of 1024 words each. A page is defined as the largest block of memory which can be addressed directly by the memory address bits of a memory reference instruction (single-length). These memory reference instructions have 10 bits to specify a memory address, and thus the page size is 1024 locations (2000 octal). Octal addresses for each page, up to the maximum memory size, are shown in table 1-1. Provision is made to address directly one of two pages: page zero (the base page, consisting of locations $00000_8$ through $01777_8$ ), and the current page (the page in which the instruction itself is located). Memory reference instructions include a bit (bit 10) reserved to specify one or the other of these two pages. To address locations in any other page, indirect addressing is used. Page references are specified by bit 10 as follows: Logic 0 = page zero (Z) Logic 1 = current page (C) ### 1-6. INDIRECT ADDRESSING All memory reference instructions reserve a bit to specify direct or indirect addressing. For single-length memory reference instructions, bit 15 of the instruction word is used; for extended arithmetic memory reference instructions, bit 15 of the address word is used. Indirect addressing uses the address part of the instruction to access another word in memory, which is taken as a new memory reference for the same instruction. This new address word is a full 16 bits long, 15 bits of address plus another direct-indirect bit. The 15-bit length of the address permits access to any location in memory. If bit 15 again specifies indirect addressing, still another address is obtained. This multiple-step indirect addressing may be done to any number of levels. The first address obtained in the indirect phase which does not specify another indirect level becomes the effective address for the instruction. Direct or indirect addressing is specified by bit 15 as follows: Logic 0 = direct Logic 1 = indirect ### 1-7. PROGRAM RELOCATION Relocatable programs are relocated at absolute addresses by the relocating loader. Relocatable code assumes a starting location of 00000, and this location is termed the relative, or *relocatable* origin. The absolute origin (termed the relocation base) of a relocatable program is determined by the loader. The value of the absolute origin is added to the zero-relative value of each operand address to obtain the absolute operand ad- dress. The absolute origin, and thus the values of every operand address, may vary each time the program is loaded. A relocatable program may be composed of several independently assembled or compiled subprograms. Each of the subprograms will have a relative origin of 00000. Each subprogram is then assigned a unique absolute origin upon being loaded. The operand values produced by the Assembler may be program relocatable, base page relocatable, or common relocatable. Each of these segments of the program has a separate relocation base or origin. Operands that are references to locations in the main portion of the program are incremented by the program relocation base; those referring to the base page, by the base page relocation base; and those referring to common storage, by the common relocation base. If the loader or system generator encounters an operand that is a reference to a location in a page other than the current page or base page, a link is established. A link is a word in the base page or current page which is allocated to contain the full 15-bit address of the referenced location. The address of the link is then substituted as an indirect address in the instruction in the current page. If other similar references are made to the same location, they are linked through the same link. ### 1-8. PROGRAM LOCATION COUNTER The Assembler maintains a counter, called the program location counter, that assigns consecutive memory addresses to source statements. The initial value of the program location counter is established according to the use of either the NAM or ORG pseudo operation at the start of the program. The NAM operation causes the program location counter to be set to zero for a relocatable program; the ORG operation specifies the absolute starting location for an absolute program. Through use of the ORB pseudo operation a relocatable program may specify that certain operations or data areas be allocated to the base page. If so, a separate counter, called the base page location counter, is used in assigning these locations. ### 1-9. SOURCE PROGRAM Figure 1-1 shows an assembler coding form and the code for a simple program which counts the number of 1's and 0's in the A-register. The first statement is the control statement, which in this example contains the assembly options R (for a relocatable source program), L (a program listing is to be output to the list file), and T (a listing of the symbol table is to be output to the list file). See paragraph 1-9 and Table 1-2 for a further discussion of control statement parameters. Table 1-1. Logical Memory Address/Pages | MEMORY<br>SIZE | PAGE | OCTAL<br>ADDRESSES | |----------------|----------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------| | 4K | 0<br>1<br>2<br>3 | 00000 to 01777<br>02000 to 03777<br>04000 to 05777<br>06000 to 07777 | | 8K | 4<br>5<br>6<br>7 | 10000 to 11777<br>12000 to 13777<br>14000 to 15777<br>16000 to 17777 | | 12K | 8<br>9<br>10<br>11 | 20000 to 21777<br>22000 to 23777<br>24000 to 25777<br>26000 to 27777 | | 16K | 12<br>13<br>14<br>15 | 30000 to 31777<br>32000 to 33777<br>34000 to 35777<br>36000 to 37777 | | 24K | 16<br>17<br>18<br>19<br>20<br>21<br>22<br>23 | 40000 to 41777<br>42000 to 43777<br>44000 to 45777<br>46000 to 47777<br>50000 to 51777<br>52000 to 53777<br>54000 to 55777<br>56000 to 57777 | | 32K | 24<br>25<br>26<br>27<br>28<br>29<br>30<br>31 | 60000 to 61777<br>62000 to 63777<br>64000 to 65777<br>66000 to 67777<br>70000 to 71777<br>72000 to 73777<br>74000 to 75777<br>76000 to 77777 | Following the control statement, the first statement of the program (other than remarks or a HED statement) must be a NAM statement for a relocatable program or an ORG statement to indicate the origin of an absolute program. The last statement must be an END statement and may contain a transfer address for the start of a relocatable program. Each statement is terminated by an end-of-statement or end-of-record mark if not on cards. ### 1-10. ASSEMBLY OPTIONS The control statement must be the first statement in the source program and it specifies the desired assembly options: $$ASMB, p_1, p_2, \ldots, p_n$$ "ASMB," is in positions 1-5 of the statement. Following the comma are one or more parameters, in any order. The parameters are shown in Table 1-2. The parameters in the control statement may be overridden when the Assembler is invoked. See Appendix E for options available at Assembler run time. Since they contradict one another, F and X must never appear in the control statement for the same source program. Similarly, A and R must never appear together. If neither A nor R is specified, R is assumed. If T is omitted, the symbol table listing will *not* be output to the list file. If L and Q are both specified, the one specified last will be used. If B is specified, it is ignored. "ASMB" alone or with either A or R as the only option specified, will direct the Assembler to process the source information without producing any output. Error messages will be output to the list device or list file, however. Thus, the user may use this method to examine the source for errors prior to producing the final object code. ### 1-11. BINARY OUTPUT The binary output is defined by the ASMB control statement. The binary output includes the object code for the instructions translated from the source program. It does not include system subroutines referenced within the source program (arithmetic subroutine calls, .IOC., .DIO., .ENTR, etc.). If a binary output file name or logical unit number is not specified in the run command for the Assembler, no binary output is produced. ### 1-12. SYMBOL TABLE Figure 1-2 shows a sample symbol table listing produced when a source program was assembled. Columns 1 through 5 contain the name of the label. Column 7 specifies the type of relocation for the operand field, and columns 9 through 14 contain the value of the label. (In the example shown in figure 1-2, the locations are relative because the source program is relocatable.) The characters that designate an external symbol or type of relocation for the Operand field or the symbol are as follows: | Character | <b>Relocation Base</b> | |--------------|------------------------| | Blank | Absolute | | R . | Program relocatable | | $\mathbf{C}$ | Common relocatable | | X | External symbol | | В | Base page relocatable | | $\mathbf{S}$ | Substitution code | | ${f E}$ | Extended Memory Area | Figure 1-1. Source Program Table 1-2. Control Statement Parameters | PARAMETER | MEANING | |-----------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | А | Absolute assembly. The addresses generated by the Assembler are to be interpreted as absolute locations in memory. The program is a complete entity; external symbols, common storage references and entry points are not permitted. Note that an absolute program <i>cannot</i> be executed on RTE. | | R | Relocatable assembly. The object program may be loaded anywhere in memory. All operands which refer to memory locations are automatically adjusted as the program is loaded. Operands referring to memory locations greater than 1777 <sub>8</sub> must be relocatable expressions. Programs may contain external symbols and entry points, and may refer to common storage. | | L | List output. A program listing is to be output to the list file or list device. Columns 8-13 of the listing will contain the object code of the instruction. This includes both the opcode and the address of the operand if it is a memory reference instruction. | | Q | List output. A program listing is to be output to the list file or list device. Columns 8-13 of the listing will contain only the operand address for single word memory reference instructions. The entire object code will be listed otherwise. | | Т | Symbol table print. A listing of the symbol table is to be printed on the standard list output device. | | N,Z | Selective assembly. Sections of the program are to be included or excluded at assembly time depending upon the option specified. See the descriptions of the IFN and IFZ pseudo instructions in Section IV of this manual. | | С | Cross reference table print. All references to statement labels, external symbols, and user-defined opcodes are to be listed on the standard list output device after the end of the assembly. | | F | Floating point instructions. The floating point machine instructions are to be used instead of the software simulation routines for the following floating point operations: FDV, FMP, FAD, and FSB. Not applicable on L-Series hardware. | | Х | No EAU hardware. Signifies that the object program will be executed on a machine which does <i>not</i> have the Extended Arithmetic Unit (EAU) hardware. This parameter prevents the use of the following EAU instructions: ASR, ASL, RRR, RRL, LSR, LSL, and SWP. In addition, it causes all occurrences of the MPY, DIV, DLD, and DST instructions to be substituted with a call to the appropriate subroutine in the relocatable library. | | Р | Used as an override option when the assembler is invoked (see Appendix E). It has no effect when specified in the control statement of an assembly language program but is included here for completeness. | | В | Ignored if specified. | ``` 1:30 PM TUE., 6 DEC., 1977 PAGE 0001 #01 0001 R 000001 ASMB, R, L, T COUNT R 000005 BIT0 R 000010 BIT1 R 000013 BIT2 R 000016 MORE R 000022 BIT3 R 000023 LESS1 R 000024 LESS2 R 000026 EVEN R 000027 NO ERRORS PASS=1 **RTE ASMB 92067-16011** ``` Figure 1-2. Symbol Table Listing ### 1-13. LIST OUTPUT | Columns | Content | |---------|-------------------------------------------------------------| | 1-4 | Source statement sequence number generated by the Assembler | | 5-6 | Blank | | 7-11 | Location (octal) | | 12 | Blank | | 13-18 | Object code word in octal | | 19 | Relocation or external symbol indicator | | 20 | Blank | | 21-80 | First 60 characters of source statement | Lines consisting entirely of comments (i.e., \* in column 1) are printed as follows: | Columns | Content | |---------|----------------------------------| | 1-4 | Source statement sequence number | | 5-80 | Up to 76 characters of comments | At the end of each pass, the following is printed on the list device: ``` Pass 1 = ** NO ERRORS PASS#1 **RTE ASMB xxxxx-yyyyy** or **nnnn ERRORS PASS#1 **RTE ASMB xxxxx-yyyyy** Pass 2 = ** NO ERRORS *TOTAL **RTE ASMB xxxxx-yyyyy** or **nnnn ERRORS *TOTAL **RTE ASMB xxxxx-yyyyyy** ``` The value nnnn indicates the number of errors. Pass 2 error count includes the total error count of pass 1 and pass 2. xxxxx-yyyyy is the Assembler's part number. If there are errors, the message PG xxx is printed on the list device immediately preceding the \*\*nnnn ERRORS\* message, where xxx is the page number where the final error was detected. The same message appears in the listing following each error and it points to the page number where the previous error was detected. The backwards pointer following the first error in the program is PG 000. A heading is printed by the Assembler at the top of every page of the list output. The heading consists of the page and tape number of the listing followed by the time of day. The HED pseudo-instruction may be used to print out a user-defined header in addition to the standard header. ### П ### **SOURCE STATEMENT FORMAT** A source language statement consists of a label, an operation code, an operand (or operands) and comments. The label is used when needed as a reference by other statements. The operation code may be a mnemonic machine operation or an assembly directing pseudo code. An operand may be an expression consisting of an alphanumeric symbol, a number, a special character, or any of these combined by arithmetic operators. An operand may also be a literal. Indicators may be appended to an operand to specify certain functions such as indirect addressing. The comments portion of the statement is optional. # 2-1. STATEMENT OF CHARACTERISTICS The fields of the source statement appear in the following order: - 1. Label - 2. Opcode - 3. Operands - 4. Comments ### 2-2. FIELD DELIMITERS One or more spaces separate the fields of a statement. A single space as the first character of a statement signifies that there is no label for this statement. ### 2-3. CHARACTER SET The characters that may appear in a statement are as follows: - A through Z - 0 through 9 - . (period) - \* (asterisk) - + (plus) - (minus) - , (comma) - = (equals) - () (parentheses) (space) Any other ASCII characters may appear in the Comments field. (See Appendix A.) The letters A through Z, the numbers 0 through 9, and the period may be used in an alphanumeric symbol. In the first position in the Label field, an asterisk indicates a comment; in the Operand field, it represents the value of the program location counter for the current instruction. The plus and minus are used as operators in arithmetic address expressions. The comma separates several operation codes, or an expression and an indicator in the Operand field. An equals sign indicates a literal value. The parentheses are used only in the COM pseudo instruction. Spaces separate fields of a statement and operands in a multi-operand field. They may also be used to enhance the appearance of the listing. Within a field they may be used freely when following +, -, $\cdot$ , or (. ### 2-4. STATEMENT LENGTH A statement may contain up to 80 characters including blanks, but excluding the end-of-statement mark. ### 2-5. LABEL FIELD The Label field identifies the statement and may be used as a reference point by other statements in the program. The field starts in position one of the statement. It is terminated by a space. A space in position one signifies that the statement is unlabeled. ### 2-6. LABEL SYMBOL A label may have one to five characters consisting of A through Z, 0 through 9, and the period. Note: The Assembler allows the use of certain other characters in the Label field. However, they are reserved for use in Hewlett-Packard programs. The first character must be alphabetic or a period. A label of more than five characters could be entered on the source statement, but the Assembler flags this condition as an error and truncates the label from the right to five characters. Some examples are shown in figure 2-1. Each label must be unique within the program; two or more statements may not have the same symbolic name. Names which appear in the Operand field of an EXT or COM pseudo instruction may not also be used as statement labels in the same subprogram. However, names appearing in a COM pseudo instruction may be defined as entry points in an ENT pseudo instruction. Some examples are shown in figure 2-2. ### 2-7. ASTERISK An asterisk in position one indicates that the entire statement is a comment. Positions 2 through 80 are available; however, positions 1 through 76 only are printed as part of the assembly listing. An asterisk within a label is illegal in any position. ### 2-8. OPCODE FIELD The operation code defines an operation to be performed by the computer or the Assembler. The Opcode field follows the Label field and is separated from it by at least one space. If there is no label, the operation code may begin anywhere after position one. The Opcode field is terminated by a space immediately following an operation code. Operation codes are organized in the following categories: Machine operation codes: - Memory Reference - Register Reference - Input/Output, Overflow, and Halt - Extended Arithmetic Unit (M; E and F-Series) - Floating Point - Memory Mapping - Decimal Arithmetic Pseudo operation codes: - Assembler control - Object program linkage - Address and symbol definition - Constant definition - Storage allocation - RTE-L Pseudo Instructions - Arithmetic subroutine calls - Assembly Listing Control - Define User Opcodes - Code-replacement definition Operation codes are discussed in detail in Sections III and IV. ### 2-9. OPERAND FIELD The meaning and format of the Operand field depend on the type of operation code used in the source statement. The field follows the Opcode field and is separated from it by at least one space. If more than one operand is required, they are separated from one another by at least one space. An Operand may contain an expression consisting of one of the following: - Single symbolic term - Single numeric term - Asterisk - Combination of symbolic terms, numeric terms, and the asterisk joined by the arithmetic operators + and An expression may be followed by a comma, an indirect addressing indicator (see paragraph 2-20), and a Clear Flag indicator (see paragraph 2-21). Programs may also contain a literal value in the Operand field. (See paragraph 2-19.) ### 2-10. SYMBOLIC TERMS A symbolic term may be one to five characters consisting of A through Z, 0 through 9, and the period. The first character must be alphabetic or a period. Some examples are shown in figure 2-3. A symbol used in the Operand field must be a symbol that is defined elsewhere in the program in one of the following ways. - As a label in the Label field of a machine operation or a user-defined instruction - As a label in the Label field of a BSS, EMA, ASC, DEC, DEX, OCT, DEF, BYT, ABS, EQU, DBL, DBR or REP pseudo operation - As a name in the Operand field of a COM or EXT pseudo operation - As a label in the Label field of an arithmetic subroutine pseudo operation The value of a symbol is absolute or relocatable depending on the assembly option selected by the user. The Assembler assigns a value to a symbol as it appears in one of the above fields of a statement. If a program is to be loaded in absolute form, the values assigned by the Assembler remain fixed. If the program is to be relocated, the actual value of a symbol is established on loading. A symbol may be assigned an absolute value through use of the EQU pseudo instruction. A symbolic term may be preceded by a plus or minus sign. If preceded by a plus or no sign, the symbol refers to its associated value. If preceded by a minus sign, the symbol refers to the two's complement of its associated value. A single negative symbolic operand may be used only with the ABS pseudo operation. Figure 2-1. Label Examples Figure 2-2. Label Usage Examples ### 2-11. NUMERIC TERMS A numeric term may be decimal or octal. A decimal number is represented by one to five digits within the range 0 to 32767. An octal number is represented by one to six octal digits followed by the letter B (0 to 177777B). If a numeric term is preceded by a plus or no sign, the binary equivalent of the number is used in the object code. If preceded by a minus sign, the two's complement of the binary equivalent is used. A negative numeric operand may be used only with the DEX, DEC, OCT, BYT and ABS pseudo operations. For a memory reference instruction in an absolute program, the maximum value of a numeric operand depends on the type of machine or pseudo instruction. In a relocatable program, the value of a numeric operand may not exceed 1777<sub>8</sub>. Numeric operands are absolute. Their value is not altered by the assembler or the loader. ### 2-12. ASTERISK An asterisk in the Operand field refers to the value in the program location counter at the time the source program statement is encountered. The asterisk is considered a relocatable term in a relocatable program. ### 2-13. EXPRESSION OPERATORS The asterisk, symbols, and numbers may be joined by the arithmetic operators + and - to form arithmetic address expressions. The Assembler evaluates an expression and produces an absolute or relocatable value in the object code. Some examples are shown in figure 2-4. ### 2-14. EVALUATION OF EXPRESSIONS An expression consisting of more than one operand is reduced to a single value. In expressions containing more than one operator, evaluation of the expression proceeds from left to right. The algebraic expression A-(B-C+5) must be represented in the Operand field as A-B+C-5. Parentheses are not permitted in operand expressions. The range of values that may result from an operand expression depends on the type of operation. The Assembler evaluates expressions as follows:† Pseudo Operations: 2 or 3-word Memory Reference: modulo 2<sup>15</sup>-1 1-word Memory Reference: modulo 210-1 Input/Output: $2^6 - 1$ (maximum value) †The evaluation of expressions by the Assembler is compatible with the addressing capability of the hardware instructions (e.g., up to 32K words through Indirect Addressing). The user must take care not to create addresses which exceed the memory size of the particular configuration. ### 2-15. EXPRESSION TERMS The terms of an expression are the numbers and the symbols appearing in it. Decimal and octal integers, and symbols defined as being absolute in an EQU pseudo operation are absolute terms. The asterisk and all symbols that are defined in the program are relocatable or absolute depending on the type of assembly. (RTE Assembler allows externals with offset and indirect external references.) Within a relocatable program, terms may be program relocatable or common relocatable or base page relocatable. A symbol that names an area of common storage is a common relocatable term. A symbol that is defined in any statement other than COM or EQU is a relocatable term. Within one expression all relocatable terms must be program relocatable, common relocatable or base page relocatable; the types may not be mixed. ### 2-16. ABSOLUTE AND RELOCATABLE EXPRESSIONS An expression is absolute if its value is unaffected by program relocation. An expression is relocatable if its value changes according to the location into which the program is loaded. In an absolute program, all expressions are absolute. In a relocatable program, an expression may be program relocatable, common relocatable, base page relocatable, or absolute (if less than 2000<sub>8</sub>) depending on the definition of the terms composing it. ### 2-17. ABSOLUTE EXPRESSIONS An absolute expression may be any arithmetic combination of absolute terms. It may contain relocatable terms alone, or in combination with absolute terms. If relocatable terms appear, there must be an even number of them; they must be of the same type; and they must be paired by sign (a negative term for each positive term). The paired terms do not have to be contiguous in the expression. The pairing of terms by type cancels the effect of relocation; the value represented by a pair remains constant. An absolute expression reduces to a single absolute value. The value of an absolute multi-term expression may be negative only for ABS pseudo operations. A single numeric term also may be negative in an OCT, DEX, BYT, or DEC pseudo instruction. In a relocatable program the value of an absolute expression must be less than $2000_8$ for instructions that reference memory locations (Memory Reference, DEF, Arithmetic subroutine calls, etc.). If $P_1$ and $P_2$ are program relocatable terms; $C_1$ and $C_2$ , common relocatable; and A, an absolute term; then the following are absolute terms: The asterisk is program relocatable. Figure 2-3. Symbolic Operand Examples Figure 2-4. Expression Operator Examples ### 2-18. RELOCATABLE EXPRESSIONS A relocatable expression is one whose value is changed by the loader. All relocatable expressions must have a positive value. A relocatable expression may contain an odd number of relocatable terms, alone, or in combination with absolute terms. All relocatable terms must be of the same type. Terms must be paired by sign with the odd term being positive. A relocatable expression reduces to a single positive relocatable term, adjusted by the values represented by the absolute terms and paired relocatable terms associated with it. If $P_1$ , $P_2$ , and $P_3$ are program relocatable terms; $C_1$ , $C_2$ and $C_3$ , common relocatable; and A, an absolute term; then the following are relocatable terms: ### 2-19. LITERALS Literal values may be specified as operands in relocatable programs. (Literals are not allowed in absolute programs.) The Assembler converts the literal to its binary value, assigns an address to it, and substitutes this address as the operand. Locations assigned to literals are those immediately following the last location used by the program. A literal is specified by using an equal sign and a onecharacter identifier defining the type of literal. The actual literal value is specified immediately following this identifier; no spaces may intervene. The identifiers are: - =D a decimal integer, in the range −32767 to 32767, including zero.† - =F a floating point number; any positive or negative real number in the range 10<sup>-38</sup> to 10<sup>38</sup>, including zero.† - an octal integer, one to six digits, $b_1b_2b_3b_4b_5b_6$ , where $b_1$ may be 0 or 1, and $b_2 b_6$ may be 0 to 7.† - =A two ASCII characters.† - =L an expression which, when evaluated, will result in an absolute value. All symbols appearing in the expression must be previously defined. If the same literal is used in more than one instruction or if different literals have the same value (e.g., =B100 and =D64), only one value is generated, and all instructions using these literals refer to the same location. Literals may be specified only in the following memory reference, register reference, EAU, and pseudo instructions: | (M, E | and F-S | leries) | | |---------------------------------|---------------------------------|-----------------------------|-----------------------------------| | ADA ADB ADX ADY AND CBS CBT CMW | CPA CPB DIV IOR LDA LDB LDX LDY | MBT JRS MPY MVW SBS TBS XOR | may use $=D$ , $=B$ , $=A$ , $=L$ | | DLD<br><b>FMP</b> | FDV<br>FAD | FSB } | may use =F | Examples are as follows: | LDA | =D7980 | A-Register is loaded with the binary equivalent of $7980_{10}$ . | |-----|------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | IOR | =B777 | Inclusive OR is performed with contents of A-Register and $777_8$ . | | LDA | =ANO | A-Register is loaded with binary representation of ASCII characters NO. | | LDB | =LZETZ-ZOOM+68 | B-Register is loaded with<br>the absolute value result-<br>ing from the expression. | | (M, | E, and F-Series) | 1. 2000年 | | FMP =] | F39.75<br>ries) | | Contents of A- and B-Registers multiplied by floating point constant 39.75. | |--------|-------------------|------------------|-------------------------------------------------------------------------------------------------------------------------| | | JSB<br>DEF<br>DEC | .FMP<br>LIT<br>0 | Jump to software simulation routine (see Section 3-28). A- and B-Registers multiplied by floating point constant 39.75. | | LIT | DEC . | 39.75 | | ### 2-20. INDIRECT ADDRESSING The HP computers provide an indirect addressing capability for memory reference instructions. The operand portion of an indirect instruction contains the address of another location. The secondary location may be the operand or it may be indirect also and give yet another location, and so forth. The chaining ceases when a location <sup>†</sup>See CONSTANT DEFINITION, Section IV. is encountered that does not contain an indirect address. Indirect addressing provides a simplified method of address modifications as well as allowing access to any location in core. See Section I, paragraph 1-5 for a further discussion of indirect addressing. The Assembler allows specification of indirect addressing by appending a comma and the letter I to any memory reference operand. The actual address of the instruction may be given in a DEF pseudo operation; this pseudo operation may also be used to indicate further levels of indirect addressing. An example is shown in figure 2-5. A relocatable assembly language program, however, may be designed without concern for the pages in which it will be stored; indirect addressing is not required in the source language. When the program is being loaded, the loader provides indirect addressing whenever it detects an operand which does not fall in the current page or the base page. The loader substitutes a reference to a program link location (established by the loader in either the base page or the current page) and then stores an indirect address in the particular program link location. If the program link location is in the base page, all references to the same operand from other pages will be via the same link location. ### 2-21. CLEAR FLAG INDICATOR The majority of the input/output instructions can alter the status of the input/output interrupt flag after execution or after the particular test is performed. In source language, this function is selected by appending a comma and a letter C to the Operand field. Some examples are shown in figure 2-6. ### 2-22. COMMENTS FIELD The Comments field allows the user to transcribe notes on the program that will be listed with source language coding on the output produced by the Assembler. The field follows the Operand field and is separated from it by at least one space. The end-of-record mark, the end-of-statement mark, CR LF , or the 80th character of a statement terminates the field. The statement length should not exceed 60 characters, the width of the source language portion of the listing. A whole line (up to 76 characters), however, can be specified as a comment by inserting an asterisk in the first position. On the list output, statements consisting entirely of comments begin in position 5 rather than 21 as with other source statements. Any characters beyond the above limits will not appear on the listing. If there is no operand present, the Comments field should be omitted in the NAM and END pseudo operations and in the input/output statements, SOC, SOS, and HLT. If a comment is used, the Assembler attempts to interpret it as an operand. This limitation applies also to multi-operand instructions. Figure 2-5. Indirect Addressing Example STC 13B, C SET CONTROL AND CLEAR THE FLAG OF SELECT CODE 13 (OCTAL) OTB 16B, C CLEAR FLAG OF SELECT CODE 16 (OCTAL) ALONG WITH OUTPUT TO DEVICE Figure 2-6. Clear Flag Examples ### **MACHINE INSTRUCTIONS** The Assembler language machine instruction codes take the form of three-letter mnemonics. Each source statement corresponds to a machine operation in the object program produced by the Assembler. Notation used in representing source language instruction is as follows: | label | Optional statement label | |----------|------------------------------------------------------------------| | m | Memory location — an expression | | I | Indirect addressing indicator | | sc | Select code - an expression | | C | Clear interrupt flag indicator | | comments | Optional comments | | [] | Brackets defining a field or portion of a field that is optional | | { } | Brackets indicating that one of the set may be selected. | | lit | literal | Instructions shaded in gray are implemented on the Mand E-Series computers that contain the optional DMS instruction set. These instructions are not implemented on the L-SERIES computers. Instructions suffixed with an asterisk are instructions implemented in software on the HP 1000 L-SERIES hardware. If the user intends to code these instructions for execution on L-SERIES hardware he should consult paragraph 3-28 and Appendix F. ### 3-1. MEMORY REFERENCE The memory reference instructions perform arithmetic, logical, jump, word manipulation, byte manipulation, and bit manipulation operations on the contents of memory locations and the registers. An instruction may directly address the 2048<sub>10</sub> words of the current and base pages. If required, indirect addressing may be used to refer to all 32,768<sub>10</sub> words of memory. Expressions in the Operand field are evaluated modulo 2<sup>10</sup>. External memory references may be made with + or - offsets, with indirects or both. If the program is to be assembled in relocatable form, the Operand field may contain relocatable or absolute expressions; however, absolute expressions must be less than $2000_8$ in value. If the program is to be assembled in absolute form, the Operand field may contain any expression which is consistent with the location of the program. Literals may not be used in absolute programs. Absolute programs must be complete entities; they may not refer to external subroutines or to common storage. ### 3-2. JUMP AND INCREMENT-SKIP Jump and Increment-Skip instructions may alter the normal sequence of program execution. | label | JMP | m [,I] | comments | |-------|-----|--------|----------| Jump to m. Jump indirect inhibits interrupt until the transfer of control is complete, or three levels of indirecting have occurred. | label | JSB | m [,I] | comments | |-------|-----|--------|----------| Jump to subroutine. The address for label +1 is placed into the location represented by m and control transfers to m+1. On completion of the subroutine, control may be returned to the normal sequence by performing a JMP m,I. | label | ISZ | m [,I] | comments | | |-------|-----|--------|----------|--| Increment, then skip if zero. ISZ adds 1 to the contents of m. If m then equals zero, the next single-word instruction in memory is skipped. ### 3-3. ADD, LOAD AND STORE Add, Load, and Store instructions transmit and alter the contents of memory and of the A- and B-Registers. A literal, indicated by "lit", may be either =D, =B, =A, or =L type. See Section II, paragraph 2-19 for a further discussion of literals. Add the contents of m to A. Add the contents of m to B. Load A with the contents of m. Load B with the contents of m. Store contents of A in m. Store contents of B in m. In each instruction, the contents of the sending location is unchanged after execution. ### 3-4. LOGICAL OPERATIONS The logical instructions allow bit manipulation and the comparison of two computer words. The logical product ("AND") of the contents of m and the contents of A are placed in A. The modulo-two sum (exclusive "or") of the bits in m and the bits in A is placed in A. The logical sum (inclusive "or") of the bits in m and the bits in A is placed in A. Compare the contents of m with the contents of A. If they differ, skip the next single word instruction; otherwise, continue. Compare the contents of m with the contents of B. If they differ, skip the next single-word instruction; otherwise, continue. ### 3-5. WORD PROCESSING The word processing instructions allow the user to move a series of data words from one array in memory to another or to compare (word-by-word) the contents of two arrays in memory. Move words. The A-register contains the starting (lowest) word address of the source array. The B-register contains the starting (lowest) word address of the destination array. These addresses $must\ not\ be\ indirect$ . The number of words to be moved is specified by literal or by the value contained in m [,I]. The specified number of words are moved from the source array into the destination array. As each word is moved, the A- and B-registers are incremented by one. The source array is not altered. Compare words. The A-register contains the starting (lowest) word address of array #1. The B-register contains the starting (lowest) word address of array #2. These addresses must not be indirect. The number of word comparisons to be performed is specified by literal or by the value contained in m [,I]. The two arrays are compared word-by-word beginning at the specified addresses. The operation is finished when an inequality is detected or when the specified number of word comparisons have been performed. When the operation is finished, the A-register contains the word address of the last word in array #1 which was compared, except when the two arrays are equal. In this case, the A-register contains the starting address of array #1, incremented by the count parameter. The B-register contains the starting address of array #2 incremented by the "count" parameter (literal or the value in m [,I]). If the two arrays are equal, execution proceeds at the next sequential source language instruction (P+3). If array #1 is "less than" #2, execution proceeds at instruction P+4. If array #1 is "greater than" array #2, execution proceeds at instruction P+5. The two arrays are not altered. ### 3-6. BYTE PROCESSING The byte processing instructions allow the user to copy a data byte from memory into the A- or B-register, copy a data byte from the A- or B-register into memory, copy a series of data bytes from one array in memory to another, compare (byte-by-byte) the contents of two arrays in memory, or scan an array in memory for particular data bytes. A byte address is defined as two times the word address of the memory location containing the particular data byte. If the byte location is the low order half of the memory location (bits 0-7), bit 0 of the byte address is set; if the byte location is the high order half of the memory location (bits 8-15), bit 0 of the byte address is clear. Byte addresses may not be indirect. Load byte. The B-register contains the byte address of the byte to be loaded. The specified byte is copied from memory into bits 0-7 of the A-register (bits 8-15 of the A-register are set to zeros). The B-register is then incremented by one. The memory location is not altered. Store byte. The B-register contains the byte address into which the byte is to be stored. Bits 0-7 of the A-register are copied into the specified memory byte location (bits 8-15 of the A-register are ignored). The B-register is then incremented by one. The A-register is not altered. Move bytes. The A-register contains the starting (lowest) byte address of the source array. The B-register contains the starting (lowest) byte address of the destination array. The number of bytes to be moved is specified by literal or by the value contained in m [,I]. The specified number of bytes are moved from the source array into the destination array. As each byte is moved, the A- and B-registers are incremented by one. The source array is not altered. Compare bytes. The A-register contains the starting (lowest) byte address of array #1. The B-register contains the starting (lowest) byte address of array #2. The number of byte comparisons to be performed is specified by literal or by the value contained in m [,I]. The two arrays are compared byte-by-byte beginning at the specified addresses. The operation is finished when an inequality is detected or when the specified number of byte comparisons have been performed. If the two arrays are equal, execution proceeds at the next sequential source language instruction (P+3); the A-register contains the address of the next byte beyond the field length and the B-register contains the starting byte address of array #2 incremented by the "count" parameter (literal or the value in m [,I]. If array #1 is "less than" array #2, execution proceeds at instruction P+4. If array #1 is "greater than" array #2, execution proceeds at instruction P+5. In both of the not-equal cases the A-register contains the byte address of the byte in array #1 where the comparison stopped and the B-register contains the starting byte address of array #2 incremented by the "count" parameter. The two arrays are not altered. | label | SFB* | comments | |-------|------|----------| Scan for byte. The A-register contains a test byte in bits 0-7 and a termination byte in bits 8-15. The B-register contains the starting (lowest) byte address of the array to be scanned. The array is compared byte-by-byte against both the test and termination bytes starting at the specified address. The operation is finished when a positive comparison is detected or when the end of memory is reached. If the test byte is detected, execution proceeds at the next sequential source language instruction (P+1) and the B-register contains the address of the test byte in the array If the termination byte is detected, execution proceeds at instruction P+2 and the B-register contains the address plus one of the termination byte in the array. The scanning operation will not continue indefinitely even if neither the termination byte nor test byte exists in memory. These bytes are in the A-register with byte addresses 000 and 001, respectively. Thus, if no match is made by the time the B-register points to the last byte in memory, the B-register will roll over to zero and the next test will match the termination byte in the A-register with itself. ### 3-7. BIT PROCESSING The bit processing instructions allow the user to selectively test, set, or clear bits in a memory location according to the contents of a mask. In the descriptions below, addr1 and addr2 may be operand expressions. Test bits. literal is a test mask, addr1[I] is the address of a memory location containing a test mask, and addr2[I] is the address of a memory location containing the bits to be tested. The bits in addr2[I] which correspond to the "1" bits in the mask are tested. All other bits in addr2[I] are ignored. If all the tested bits in addr2[I] are set, execution proceeds at the next sequential source language instruction (P+3). If any of the tested bits in addr2[I] are clear, execution proceeds at instruction P+4. Set bits. literal is a mask, addr1[I] is the address of a memory location containing a mask, and addr2[I] is the address of a memory location containing the bits to be set. The bits in addr2[I] which correspond to the "1" bits in the mask are set. All other bits in addr2[I] are not affected. Functionally, the SBS instruction is a "logical OR" operation. Clear bits. literal is a mask, addr1[I] is the address of a memory location containing a mask, and addr2[I] is the address of a memory location containing the bits to be cleared. The bits in addr2[I] which correspond to the "1" bits in the mask are cleared. All other bits in addr2[I] are not affected. ### 3-8. REGISTER REFERENCE The register reference instructions include a shift-rotate group, an alter-skip group, an index register group, and NOP (no operation). For the shift-rotate and alter-skip groups, the instruction mnemonics within each group may be combined into a single source statement to cause multiple operations to be executed during one memory cycle. In such cases, successive mnemonics within a single source statement are separated from one another by a comma. ### 3-9. SHIFT-ROTATE GROUP This group contains 19 basic instructions that can be combined to produce more than 500 different single cycle operations. CLE Clear E to zero ALS Shift A left one bit, zero to least significant bit. Sign unaltered BLS Shift B left one bit, zero to least significant bit. Sign unaltered ARS Shift A right one bit, extend sign; sign unaltered BRS Shift B right one bit, extend sign; sign unaltered RAL Rotate A left one bit RBL Rotate B left one bit RAR Rotate A right one bit RBR Rotate B right one bit ALR Shift A left one bit, clear sign, zero to least significant bit BLR Shift B left one bit, clear sign, zero to least significant bit ERA Rotate E and A right one bit ERB Rotate E and B right one bit ELA Rotate E and A left one bit ELB Rotate E and B left one bit ALF Rotate A left four bits BLF Rotate B left four bits SLA Skip next single-word instruction if least sig- nificant bit in A is zero SLB Skip next single-word instruction if least sig- nificant bit in B is zero These instructions may be combined as follows: label $$\left\{ \begin{pmatrix} ALS \\ ARS \\ RAL \\ RAR \\ ALR \\ ALF \\ ERA \\ ELA \end{pmatrix} \right]$$ [,CLE] [,SLA] $\left\{ \begin{pmatrix} ALS \\ ARS \\ RAL \\ RAR \\ ALR \\ ALF \\ ERA \\ ELA \end{pmatrix} \right\}$ comments $$\begin{bmatrix} \left\{ \begin{array}{c} BLS \\ BRS \\ RBL \\ RBR \\ BLR \\ BLF \\ ERB \\ ELB \\ \end{array} \right\} \begin{bmatrix} [,CLE] \ [,SLB] \\ [,SLB] \\ [,CLE] \ [,SLB] \ [,SLB] \\ [,SLB] \ [,SLB] \\ [,SLB] \ [,SLB] \\ [,SLB] \ [,SLB] \\ [,SLB] \ [,SLB] \ [,SLB] \\ [,SLB] \ [,SLB] \ [,SLB] \ [,SLB] \\ [,SLB] \ \$$ The shift-rotate instructions must be given in the order shown. At least one and up to four are included in one statement. Instructions referring to the A-register may not be combined in the same statement with those referring to the B-register. ### 3-10. ALTER-SKIP GROUP The alter-skip group contains 19 basic instructions that can be combined to produce more then 700 different single cycle operations. CLA Clear the A-Register CLB Clear the B-Register CMA Complement the A-Register CMB Complement the B-Register CCA Clear, then complement the A-Register (set to ones) CCB Clear, then complement the B-Register (set to ones) CLE Clear the E-Register CME Complement the E-Register CCE Clear, then complement the E-Register SEZ Skip next single-word instruction if E is zero | SSA | Skip if sign of A is positive (0) | |-----|-------------------------------------------------------------------------------------------------------------------------------| | SSB | Skip if sign of B is positive (0) | | INA | Increment A by one | | INB | Increment B by one | | SZA | Skip if contents of A equals zero | | SZB | Skip if contents of B equals zero | | SLA | Skip if least significant bit of A is zero | | SLB | Skip if least significant bit of B is zero | | RSS | Reverse the sense of the skip instructions. If no<br>skip instructions precede in the statement, skip<br>the next instruction | These instructions may be combined as follows: | label | $\begin{bmatrix} \left\{ \begin{matrix} CLA \\ CMA \\ CCA \end{matrix} \right\} \text{ [,SEZ] } \begin{bmatrix} \left\{ \begin{matrix} CLE \\ CME \\ CCE \end{matrix} \right\} \text{ [,SSA] [,SLA] [,INA] [,SZA] [,RSS]} \end{bmatrix}$ | comments | |-------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------| | label | $ \begin{bmatrix} CLB \\ CMB \\ CCB \end{bmatrix} [,SEZ] \begin{bmatrix} CLE \\ CME \\ CCE \end{bmatrix} [,SSB] [,SLB] [,INB] [,SZB] [,RSS] $ | comments | The alter-skip instructions must be given in order shown. At least one and up to eight are included in one statement. Instructions referring to the A-register may not be combined in the same statement with those referring to the B-register. When two or more skip functions are combined in a single operation, a skip occurs if any one of the conditions exists. If a word with RSS also includes both SSA and SLA (or SSB and SLB), a skip occurs only when sign and least significant bit are both set (1). ### 3-11. INDEX REGISTER GROUP This group contains 32 instructions which perform various operations involving the use of index registers X and Y. Instructions in this group may directly address all $32,768_{10}$ words of memory. Indirect addressing may also be used if desired. | label | CAX* | comments | |-------|------|----------| Copy A to X. The contents of the A-register are copied into the X-register. The A-register is not altered. | label | CBX* | comments | | |-------|------|----------|--| Copy B to X. The contents of the B-register are copied into the X-register. The B-register is not altered. | | l | l | |-------|------|----------| | label | CAY* | comments | Copy A to Y. The contents of the A-register are copied into the Y-register. The A-register is not altered. | label | CBY* | comments | |-------|------|----------| Copy B to Y. The contents of the B-register are copied into the Y-register. The B-register is not altered. | label | CXA* | comments | | |-------|------|----------|--| Copy X to A. The contents of the X-register are copied into the A-register. The X-register is not altered. | | <b>1</b> | <u> </u> | |-------|----------|----------| | label | CXB* | comments | Copy X to B. The contents of the X-register are copied into the B-register. The X-register is not altered. | | l | L | |-------|------|----------| | label | CYA* | comments | Copy Y to A. The contents of the Y-register are copied into the A-register. The Y-register is not altered. | | L | | | |-------|------|----------|--| | label | CYB* | comments | | Copy Y to B. The contents of the Y-register are copied into the B-register. The Y-register is not altered. | | L | | | |-------|------|----------|--| | label | XAX* | comments | | Exchange A and X. The contents of the A-register are copied into the X-register and the contents of the X-register are copied into the A-register. Exchange B and X. The contents of the B-register are copied into the X-register and the contents of the X-register are copied into the B-register. Exchange A and Y. The contents of the A-register are copied into the Y-register and the contents of the Y-register are copied into the A-register. | | L | | | |-------|------|----------|--| | label | XBY* | comments | | Exchange B and Y. The contents of the B-register are copied into the Y-register and the contents of the Y-register are copied into the B-register. Increment X and skip if zero. The contents of the X-register are incremented by one and then tested. If the new value in X is zero, the next sequential single-word instruction (P+1) is skipped and execution proceeds at instruction P+2; if the new value in X is non-zero, execution proceeds at instruction P+1. Increment Y and skip if zero. The contents of the Y-register are incremented by one and then tested. If the new value in Y is zero, the next sequential single-word instruction (P+1) is skipped and execution proceeds at instruction P+2; if the new value in Y is non-zero, execution proceeds at instruction P+1. Decrement X and skip if zero. The contents of the X-register are decremented by one and then tested. If the new value in X is zero, the next sequential instruction (P+1) is skipped and execution proceeds at instruction P+2; if the new value in X is non-zero, execution proceeds at instruction P+1. | label | DSY* | comments | |-------|------|----------| Decrement Y and skip if zero. The contents of the Y-register are decremented by one and then tested. If the new value in Y is zero, the next sequential single-word instruction (P+1) is skipped and execution proceeds at instruction P+2; if the new value in Y is non-zero, execution proceeds at instruction P+1. | | L | ( [ ]] | | |-------|------|-------------------------------------------------------------------|----------| | label | LDX* | $\left\{\begin{array}{c} m \ [,1] \\ literal \end{array}\right\}$ | comments | Load X from memory. The contents of the specified memory location are copied into the X-register. Indirect addressing may be used. The memory location is not altered. | label | LDY* | m [,I] literal | comments | |-------|------|----------------|----------| Load Y from memory. The contents of the specified memory location are copied into the Y-register. Indirect addressing may be used. The memory location is not altered. | label | STX* | m [,I] | comments | |-------|------|--------|----------| Store X into memory. The contents of the X-register are copied into the specified memory location. Indirect addressing may be used. The X-register is not altered. | label | STY* | m [,I] | comments | |-------|------|--------|----------| Store Y into memory. The contents of the Y-register are copied into the specified memory location. Indirect addressing may be used. The Y-register is not altered. | | L | | | |-------|------|--------|----------| | label | LAX* | m [,I] | comments | Load A from memory indexed by X. The contents of the specified memory location are copied into the A-register. Indirect addressing may be used. The address of the memory location is computed by adding the contents of the X-register to m or to m, I. Note that indirect addressing (if specified) is performed first and then the address is indexed. The X-register and the memory location are not altered. | | | | l | |-------|------|--------|----------| | label | LBX* | m [,I] | comments | Load B from memory indexed by X. The contents of the specified memory location are copied into the B-register. Indirect addressing may be used. The address of the memory location is computed by adding the contents of the X-register to m or to m, I. Note that indirect addressing (if specified) is performed first and then the address is indexed. The X-register and the memory location are not altered. | | L | | | |-------|------|--------|----------| | label | LAY* | m [,I] | comments | Load A from memory indexed by Y. The contents of the specified memory location are copied into the A-register. Indirect addressing may be used. The address of the memory location is computed by adding the contents of the Y-register to m or to m, I. Note that indirect addressing (if specified) is performed first and then the address is indexed. The Y-register and the memory location are not altered. | | | 1 | <b>.</b> | |-------|------|--------|----------| | label | LBY* | m [,I] | comments | Load B from memory indexed by Y. The contents of the specified memory location are copied into the B-register. Indirect addressing may be used. The address of the memory location is computed by adding the contents of the Y-register to m or to m, I. Note that indirect addressing (if specified) is performed first and then the address is indexed. The Y-register and the memory location are not altered. Store A into memory indexed by X. The contents of the A-register are copied into the specified memory location. Indirect addressing may be used. The address of the memory location is computed by adding the contents of the X-register to m or to m, I. Note that indirect addressing (if specified) is performed first and then the address is indexed. The A-register and the X-register are not altered. Store B into memory indexed by X. The contents of the B-register are copied into the specified memory location. Indirect addressing may be used. The address of the memory location is computed by adding the contents of the X-register to m or to m,I. Note that indirect addressing (if specified) is performed first and then the address is indexed. The B-register and the X-register are not altered. Store A into memory indexed by Y. The contents of the A-register are copied into the specified memory location. Indirect addressing may be used. The address of the memory location is computed by adding the contents of the Y-register to m or to m, I. Note that indirect addressing (if specified) is performed first and then the address is indexed. The A-register and the Y-register are not altered. Store B into memory indexed by Y. The contents of the B-register are copied into the specified memory location. Indirect addressing may be used. The address of the memory location is computed by adding the contents of the Y-register to m or to m, I. Note that indirect addressing (if specified) is performed first and then the address is indexed. The B-register and the Y-register are not altered. | label | ADX* | m [,I] | comments | |-------|------|--------|----------| Add memory to X. The contents of the specified memory location are algebraically added to the contents of the X-register. Indirect addressing may be used. The memory location is not altered. Add memory to Y. The contents of the specified memory location are algebraically added to the contents of the Y-register. Indirect addressing may be used. The memory location is not altered. | | L | | L | |-------|------|--------|----------| | label | JLY* | m [,I] | comments | Jump and load Y. Control transfers unconditionally to the specified memory location and the address P+2 is loaded into the Y-register. Indirect addressing may be used. This instruction is used for calling subroutines. The subroutines use the Y-register to access parameters and to return control (by way of the JPY instruction) to the calling program. | label | JPY* | m | comments | |-------|------|---|----------| Jump indexed by Y. Control transfers unconditionally to the specified memory location. Indirect addressing may *not* be used. The address of the memory location is computed by adding the contents of the Y-register to m. This instruction is used for returning control from subroutines to the calling program (assuming that they were entered by way of JLY instructions). ### 3-12. NO-OPERATION INSTRUCTION When a no-operation is encountered in a program, no action takes place; the computer goes on to the next instruction. A full memory cycle is used in executing a no-operation instruction. A subroutine to be entered by a JSB instruction should have a NOP as the first statement. The return address can be stored in the location occupied by the NOP during execution of the program. A NOP statement causes the Assembler to generate a word of zero. ### 3-13. INPUT/OUTPUT, OVERFLOW, AND HALT The input/output instructions allow the user to transfer data to and from an external device, to enable or disable external interrupts, and to check the status of I/O devices and operations. Input/output instructions are also used to control CPU functions such as memory protect, power fail recovery and overflow conditions. Input/output instructions require the designation of a select code, sc, which indicates one of $64_{10}$ input/output channels or functions. Note: When Memory Protect is enabled, execution of most I/O instructions is prohibited. Expressions used to represent select codes must have a value of less than 2<sup>6</sup>. The value specifies the device or operation referenced. Unlike memory reference instruc- tions, I/O instructions cannot use indirect links. The select code (sc) may be a label which was previously defined as an external symbol by an EXT pseudo-instruction. In such a case, the entry point referred to by the EXT pseudo-instruction must be an absolute value less than $64_{10}$ (any other value will change the instruction. Since input/output instructions are generally hardware/architecture dependent, the instructions presented here are meant to be used as a summary and coding guide. The user is referred to the appropriate CPU hardware manual for a detailed description of the I/O architecture and its operation. ### 3-14. INPUT/OUTPUT Assembly language programs normally perform I/O through calls to EXEC. Consult the appropriate RTE Programming and Operating manual for more information. If the memory protect hardware option is present and enabled, it protects the operating system from alteration. Most instructions of this section cause memory protect violations to occur. They are included here for users who desire to write their own drivers. To perform I/O, the programming, installation and service manuals of the CPU and I/O card being programmed should be consulted for the meaning of these instructions. RTE-L users should refer to the RTE-L Driver Designer's manual for the operating system and I/O conventions. | label | STC | sc [,C] | comments | |-------|-----|---------|----------| Set I/O control bit specified by sc. | label | CLC | sc [,C] | comments | |-------|-----|---------|----------| Clear I/O control bit specified by sc. | label | LIA | sc [,C] | comments | |-------|-----|---------|----------| Load into A the contents of the I/O buffer indicated by sc. Load into B the contents of the I/O buffer indicated by sc. | | | L | | |-------|-----|---------|----------| | label | MIA | sc [,C] | comments | Merge (inclusive "or") the contents of the I/O buffer indicated by sc into A. Merge (inclusive "or") the contents of the I/O buffer indicated by sc into B. | | 1 | | | |-------|-----|---------|----------| | label | ОТА | sc [,C] | comments | Output the contents of A to the I/O buffer indicated by sc. | label | ОТВ | sc [,C] | comments | |-------|-----|---------|----------| Output the contents of B to the I/O buffer indicated by sc. Set the flag bit indicated by sc. Clear the flag bit to zero indicated by sc. Skip the next single-word instruction if the flag indicated by sc is clear. Skip the next single-word instruction if the flag bit indicated by sc is set. If sc = 1, the overflow is tested. ### 3-15. OVERFLOW The overflow bit may be accessed by the following instructions: Clear the overflow bit. Set overflow bit. Skip the next single-word instruction if the overflow bit is clear. The C option clears the bit after the test is performed. Skip the next single-word instruction if the overflow bit is set. The C option clears the bit after the test is performed. The C option is identified by the sequence "space C space" following either "SOC" or "SOS". Any letter other than a "C" in this position will be treated as a comment. ### 3-16. HALT Halt the computer. The machine instruction word is displayed in the T-register. If the C option is used, the flag bit associated with channel sc is cleared. If neither the select code nor the C option is used, the comments portion must be omitted. # 3-17. EXTENDED ARITHMETIC UNIT (EAU) The MPY instruction multiplies the contents of the A-Register by the contents of m. The product is stored in registers B and A. B contains the sign of the product and the 15 most significant bits; A contains the least significant bits. The DIV instruction divides the contents of registers B and A by the contents of m. The quotient is stored in A and the remainder in B. Initially B contains the sign and the 15 most significant bits of the dividend; A contains the least significant bits. The DLD instruction loads the contents of locations m and m+1 into registers A and B, respectively. | | | | • | |-------|-----|--------|----------| | label | DST | m [,I] | comments | The DST instruction stores the contents of registers A and B in locations m and m+1, respectively. MPY, DIV, DLD, DST results in two machine words: a word for the instruction code and one for the operand. The following seven instructions provide the capability to shift or rotate the B- and A-Registers n number of bit positions to the right or left, where $1 \le n \le 16$ . | | | L | | |-------|-----|---|----------| | label | ASR | n | comments | The ASR instruction arithmetically shifts the B- and A-Registers right n bits. The sign bit (bit 15 of B) is extended. | | L1 | | | |-------|-----|---|----------| | label | ASL | n | comments | The ASL instruction arithmetically shifts the B- and A-Register left n bits. Zeroes are placed in the least significant bits. The sign bit (bit 15 of B) is unaltered. The overflow bit is set if bit 14 differs from bit 15 before each shift; otherwise, exit with overflow bit cleared. | | Li | | L | |-------|-----|---|----------| | label | RRR | n | comments | The RRR instruction rotates the B- and A-Registers right n bits. | label | RRL | n | comments | |-------|-----|---|----------| The RRL instruction rotates the B- and A-Registers left n bits. | | | L | L | |-------|-----|---|----------| | label | LSR | n | comments | The LSR instruction logically shifts the B- and A-Registers right n bits. Zeroes are placed in the most significant bits. The LSL instruction logically shifts the B- and A-Registers left n bits. Place zeroes into the least significant bits. Exchange the contents of the A- and B-Registers. The contents of the A-Register are shifted into the B-Register and the contents of the B-Register are shifted into the A-Register. ### 3-18. FLOATING POINT The instructions in this group are used for performing arithmetic operations on floating point operands. The user specifies whether or not floating point machine instructions are available via a parameter in the control statement (see table 1-2). If the floating point machine instructions are *not* available, the instructions in this group result in calls to arithmetic subroutines except for FIX and FLT (see paragraph 4-7). The Operand field may contain any relocatable expression or absolute expression resulting in a value of less than 2000<sub>8</sub>. Multiply the two-word floating point quantity in registers A and B by the two-word floating point quantity in locations m and m+1 or the quantity defined by the literal. Store the two-word floating point product in registers A and B. label $$FDV^*$$ $\left\{ \begin{array}{l} m \ [,I] \\ =Fn \end{array} \right\}$ comments Divide the two-word floating point quantity in registers A and B by the two-word floating point quantity in locations m and m+1 or the quantity defined by the literal. Store the two-word floating point quotient in A and B. $$\begin{array}{c|c} \text{label} & \text{FAD}^* & \left\{ \begin{array}{c} \text{m [,I]} \\ = \text{FN} \end{array} \right\} & \text{comments} \end{array}$$ Add the two-word floating point quantity in registers A and B to the two-word floating point quantity in locations m and m+1 or the quantity defined by the literal. Store the two-word floating point sum in A and B. | label | FSB* | $ \left\{ \begin{array}{l} m [,I] \\ =Fn \end{array} \right\} $ | comments | |-------|------|-----------------------------------------------------------------|----------| Subtract the two-word floating point quantity in m and m+1 or the quantity defined by the literal from the two-word floating point quantity in registers A and B and store the difference in A and B. Convert the floating-point number contained in the A- and B-registers to a fixed-point number. The result is returned in the A-register. After the operation is completed, the contents of the B-register are meaningless. | label | FLT* | comments | |-------|------|----------| Convert the fixed-point number contained in the A-register to a floating-point number. The result is returned in the A-and B-registers. # 3-19. DYNAMIC MAPPING SYSTEM (M, E AND F-SERIES ONLY) The basic addressing space of the HP 1000 Computer Series is 32,768 words, which is referred to as logical memory. The amount of memory actually installed in the computer system is referred to as physical memory. An HP 1000 Computer with the optional Dynamic Mapping System (DMS) has an addressing capability for one million words of memory. The DMS allows physical memory to be mapped into logical memory through the use of four dynamically alterable memory maps. ### 3-20. MEMORY ADDRESSING The basic memory addressing scheme provides for addressing 32 pages of logical memory, each of which consists of 1,024 words. This memory is addressed through a 15-bit memory address bus shown in figure 3-1. The upper 5 bits of this bus provide the page address and the lower 10 bits provide the relative word address within the page. The Memory Expansion Module (MEM), which is part of the DMS option, converts the 5-bit page address into a 10-bit page address and thereby allows 1,024 (2<sup>10</sup>) pages to be addressed. This conversion is accomplished by allowing the original 5-bit address to identify one of the 32 registers within a "memory map." Each of these map registers contains the new user-specified 10-bit page address. This new page address is combined with the original 10-bit relative address to form a 20-bit memory address bus as shown in figure 3-2. ### 3-21. STATUS AND VIOLATION REGISTERS The MEM also includes a status register and a violation register. As shown in table 3-1, the MEM status register contents enable the programmer to determine whether the MEM was enabled or disabled at the time of the last interrupt and the address of the base page fence. The MEM Figure 3-1. Basic Memory Addressing Scheme Figure 3-2. Expanded Memory Addressing Scheme Table 3-1. MEM Status Register Format | віт | SIGNIFICANCE | |---------|--------------------------------------------------------------------------------------| | 15 | 0 = MEM disabled at last interrupt<br>1 = MEM enabled at last interrupt | | 14 | 0 = System map selected at last interrupt<br>1 = User map selected at last interrupt | | .13 | 0 = MEM disabled currently 1 = MEM enabled currently | | 12 | 0 = System map selected currently<br>1 = User map selected currently | | 11 | 0 = Protected mode disabled currently 1 = Protected mode enabled currently | | 10 | Portion mapped* | | 9 | Base page fence bit 9 | | 8 | Base page fence bit 8 | | 7 | Base page fence bit 7 | | 6 | Base page fence bit 6 | | 5 | Base page fence bit 5 | | 4 | Base page fence bit 4 | | 3 | Base page fence bit 3 | | 2 | Base page fence bit 2 | | 1 | Base page fence bit 1 | | 0 | Base page fence bit 0 | | *Bit 10 | Mapped Address (M) | | | Fence ≤ M < 2000 <sub>8</sub> 1 < M < Fence | violation register contents enable the programmer to determine whether a fault occurred in the hardware or the software so that the proper corrective steps may be taken. Refer to table 3-2. ### 3-22. MAP SEGMENTATION All registers within the memory map are dynamically alterable. The MEM includes four separate memory maps: the User Map, System Map, and two Dual-Channel Port Controller (DCPC) Maps. See figure 3-3. These maps are addressed as a contiguous register block. ### 3-23. POWER FAIL CHARACTERISTICS A power failure automatically enables the System Map, and a minimum of 500 microseconds is assured the programmer for executing a power fail routine. Since all maps are disabled and none are considered valid upon the restoration of power, the power fail routine should include instructions to save as many maps as desired. Table 3-2. MEM Violation Register Format | )T | SIGNIFICANCE | |----|--------------------------------------------------------------------------| | 15 | Read violation* | | 14 | Write violation* | | 13 | Base page violation* | | 12 | Privileged instruction violation* | | 11 | Reserved | | 10 | Reserved | | 9 | Reserved | | 8 | Reserved | | 7 | 0 = ME bus disabled at violation<br>1 = ME bus enabled at violation | | 6 | 0 = MEM disabled at violation<br>1 = MEM enabled at violation | | 5 | 0 = System map enabled at violation<br>1 = User map enabled at violation | | 4 | Map address bit 4 | | 3 | Map address bit 3 | | 2 | Map address bit 2 | | 1 | Map address bit 1 | | 0 | Map address bit 0 | Figure 3-3. Map Segmentation ### 3-24. PROTECTED MODE The protected mode of operation is a program state created by the Dynamic Mapping System. The protected mode is entered by executing an STC 05 instruction and is exited by the CPU acknowledging an interrupt. The protected mode reserves a block of memory and prevents access to this block by other users. ### 3-25. MEM VIOLATION An interrupt request which attempts to access the protected block of memory (while in the protected mode) will cause a MEM violation. ### 3-26. DYNAMIC MAPPING SYSTEM INSTRUCTIONS If the computer on which the object program is to be run includes a Dynamic Mapping System, the following group of instructions may be used. Disable MEM and jump. This instruction disables the translation and protection features of the MEM hardware. Prior to disabling, the P-register is set to the effective memory address. As a result of executing this instruction, normal I/O interrupts are held off until the first opportunity following the fetch of the next instruction, unless three or more levels of indirect addressing are used. This instruction will normally generate a MEM violation when executed in the protected mode. In this case, the status of the MEM is not affected and the jump will not occur; however, if the System map is enabled, the instruction is allowed. If none of the maps are enabled, the instruction defaults to JMP\*+1,I. Disable MEM and jump to subroutine. This instruction disables the translation and protection features of the MEM hardware. Prior to disabling, the P-register is set one count past the effective memory address. The return address is written into the location specified by m[,I]. As a result of executing this instruction, normal I/O interrupts are held off until the first opportunity following the fetch of the next instruction, unless three or more levels of indirect addressing are used. This instruction will normally generate a MEM violation when executed in the protected mode. In this case, the status of the MEM is not affected and the jump will not occur; however, if the System map is enabled, the instruction is allowed. Jump and restore status. addr1 contains the address of the status word memory location, literal specifies the status word, and addr2 contains the jump address. This instruction causes the status of MEM to be restored as indicated by bits 15 and 14 of the status word. Only bits 15 and 14 of the status word are used; the remaining bits (13-0) of the status word are ignored. Bits 15 and 14 restore the MEM status as follows: Bit 15 = 0 MEM is disabled Bit 15 = 1 MEM is enabled Bit 14 = 0 System map is selected Bit 14 = 1 User map is selected. As a result of executing this instruction, normal I/O interrupts are held off until the first opportunity following the fetch of the next instruction, unless three or more levels of indirect addressing are used. This instruction will normally generate a MEM violation when executed in the protected mode. In this case, the status of the MEM is not affected and the jump will not occur; however, if the System map is enabled, the instruction is allowed. Load fence from A. This instruction loads the contents of the A-register into the base page fence register. (The base page fence register contains the "fence" address, which specifies the address where reserved (mapped) memory begins. Attempts to access memory at any address below this fence will not be allowed.) Bits 9 through 0 of the A-register specify the address in page zero where shared (unmapped) memory is separated from reserved (mapped) memory. Bit 10 is used as follows to specify which portion is mapped: | Bit 10 | Mapped Address (M) | |--------|------------------------------------------------| | 0 | Fence ≤ M < 2000 <sub>8</sub><br>1 < M < Fence | This instruction will always generate a MEM violation when executed in the protected mode. In this case, the fence is not altered. However, if the System map is enabled, the instruction is allowed in protected mode. | | | | FF | | | | |-------|-----|-----|-----------------|---------------------|-------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | label | | FB | comm | مقمته | | | | lauci | .14 | P.D | COMM | enus | | | | | | 100 | - No. 140 Miles | C. 30-800 J. E. 811 | The Hamber School | The Court of the State S | Load fence from B. This instruction loads the contents of the B-register into the base page fence register. Bits 9 through 0 of the B-register specify the address in page zero where shared (unmapped) memory is separated from reserved (mapped) memory. Bit 10 is used as follows to specify which portion is mapped: | | Bit | : 10 | ) (1<br>) (1 | M | app | ed | Ad | ldr | <b>889</b> | (M | () | - 58<br>13 (9) | 25<br>15 | | V. | |--|-----|--------|--------------|----|-----|---------|-------|-----|------------|------------|----|----------------|----------|--|----| | | | 9<br>1 | * | Fe | | - n F 8 | 11.00 | | 86. 75 | 000<br>enc | | | | | | This instruction will always generate a MEM violation when executed in the protected mode. In this case, the fence is not altered. However, if the System map is enabled, the instruction is allowed in protected mode. | 100 Mg # 8 | | | | |------------|-----|----------|---| | label | MBF | comments | | | | | | Ġ | Move bytes from alternate map. This instruction moves a string of bytes using the alternate program map for source reads and the currently enabled map for destination writes. (The alternate map is the map which is not enabled. For example, if the system map is enabled, the User map is the alternate map and vice versa.) The A-register contains the source byte address and the B-register contains the destination byte address. The X-register contains the octal number of bytes to be moved. Both the source and destination byte address must begin on even word boundaries. This instruction is interruptible on an even number of byte transfers, thus maintaining the even word boundaries in the A- and B-registers. The interrupt routine is expected to save and restore the current contents of the A-, B-, and X-registers to allow continuation of the instruction at the next entry. When the byte string move is completed, the X-register will always be zero and the A- and B-registers will contain their original value incremented by the number of bytes moved. This instruction can cause a MEM violation only if read or write protection rules are violated. (For example, if an attempt is made to write to the reserved (mapped) section of memory.) | j | | | | |---|-------|-------|------------| | 5 | label | MBI | comments | | | label | ***** | Continents | | | | | | Move bytes into alternate map. This instruction moves a string of bytes using the currently enabled map for source reads and the alternate program map for destination writes. The A-register contains the source byte address and the B-register contains the destination byte address. The X-register contains the octal number of bytes to be moved. Both the source and destination byte addresses must begin on even word boundaries. This instruction is interruptible on an even number of byte transfers, thus maintaining the even word boundaries in the A- and B-registers. The interrupt routine is expected to save and restore the current contents of the A-, B-, and X-registers to allow continuation of the instruction at the next entry. When the byte string move is completed, the X-register will always be zero and the A- and B-registers will contain their original value incremented by the number of bytes moved. This instruction will always cause a MEM violation when executed in the protected mode and no bytes will be transferred. | label | MBW comments | | |-------|--------------|--| | raner | MBW comments | | | | | | Move bytes within alternate map. This instruction moves a string of bytes with both the source and destination addresses established through the alternate program map. The A-register contains the source byte address and the B-register contains the destination byte address. The X-register contains the octal number of bytes to be moved. Both the source and destination byte addresses must begin on even word boundaries. This instruction is interruptible on an even number of byte transfers, thus maintaining the even word boundaries in the A- and B-registers. The interrupt routine is expected to save and restore the current contents of the A-, B- and X-registers to allow continuation of the instruction at the next entry. When the byte string move is completed, the X-register will always be zero and the A- and B-registers will contain their original value incremented by the number of bytes moved. This instruction will always cause a MEM violation when executed in the protected mode and no bytes will be transferred. | label | MWF | comments | | |-------|-----|--------------|--| | | | 나는 화생선 지난 선물 | | Move words from alternate map. This instruction moves a string of words using the alternate program map for source reads and the currently enabled map for destination writes. The A-register contains the source address and the B-register contains the destination address. The X-register contains the octal number of words to be moved. This instruction is interruptible. The interrupt routine is expected to save and restore the current contents of the A-B-, and X-registers to allow continuation of the instruction at the next entry. When the word string move is completed, the X-register will always be zero and the A- and B-registers will contain their original value incremented by the number of words moved. This instruction can cause a MEM violation only if read and write protection rules are violated. | | G Balante | | 19 - 19 - 19 - 19 - 19 - 19 - 19 - 19 - | | |-------|-----------|----------|-----------------------------------------|--| | label | MWI | comments | | | | | | | | | Move words into alternate map. This instruction moves a string of words using the currently enabled map for source reads and the alternate program map for destination writes. The A-register contains the source address and the B-register contains the destination address. The X-register contains the octal number of words to be moved. This instruction is interruptible. The interrupt routine is expected to save and restore the current contents of the A-, B-, and X-registers to allow continuation of the instruction at the next entry. When the word string move is completed, the X-register will always be zero and the A- and B-registers will contain their original value incremented by the number of words moved. This instruction will always cause a MEM violation when executed in the protected mode and no words will be transferred. | | | | | in Name is | |-------|-----|--------|-----|------------| | label | MWW | commer | nts | | | | | | | | Move words within alternate map. This instruction moves a string of words with both the source and destination addresses established through the alternate program map. The A-register contains the source address and the B-register contains the destination address. The X-register contains the octal number of words to be moved. This instruction is interruptible. The interrupt routine is expected to save and restore the current contents of the A-, B-, and X-registers to allow continuation of the instruction at the next entry. When the word string move is completed, the X-register will always be zero and the A- and B-registers will contain their original value incremented by the number of words moved. This instruction will always cause a MEM violation when executed in the protected mode and no words will be transferred. | | <u> </u> | | ·′ | | |-------|----------|----------|----|--| | label | PAA | comments | | | Load/store Port A map per A. This instruction transfers the 32 Port A map registers to or from memory. If bit 15 of the A-register is clear, the Port A map is loaded from memory starting from the address specified in bits 14-0 of the A-register. If bit 15 of the A-register is set, the Port A map is stored into memory starting at the address specified in bits 14-0 of the A-register. When the load/store operation is complete, the A-register will be incremented by 32 to allow multiple map instructions. An attempt to load any map register when in the protected mode will cause a MEM violation. An attempt to store the Port A map is allowed within the constraints of write protected memory. | | | 13 5 7 9 R 1 5 7 1 8 | | |-------|-----|----------------------|--| | label | PAB | comments | | | | | Mary 1997 | | Load/store Port A map per B. This instruction transfers the 32 Port A registers to or from memory. If bit 15 of the B-register is clear, the Port A map is loaded from memory starting from the address specified in bits 14-0 of the B-register. If bit 15 of the B-register is set, the Port A map is stored into memory starting at the address specified in bits 14-0 of the B-register. When the load/store operation is complete, the B-register will be incremented by 32 to allow multiple map instructions. An attempt to load any map register when in the protected mode will cause a MEM violation. An attempt to store the Port A map is allowed within the constraints of write protected memory. | nga kan 1960 | | | | 13 3.7 52 | | |--------------|---------------|----------------------|------|-----------|-----------------| | 111 | and a Barbara | 974777 | | 1000 | Ş., | | label | PBA | comme | ents | | North Control | | | | La like baggar da da | | 얼룩소 | 31 - E (14 A) 1 | Load/store Port B map per A. This instruction transfers the 32 Port B registers to or from memory. If bit 15 of the A-register is clear, the Port B map is loaded from memory starting from the address specified in bits 14-0 of the A-register. If bit 15 of the A-register is set, the Port B map is stored into memory starting at the address specified in bits 14-0 of the A-register. When the load/store operation is complete, the A-register will be incremented by 32 to allow multiple map instructions. An attempt to load any map register when in the protected mode will cause a MEM violation. An attempt to store the Port B map is allowed within the constraints of write protected memory. | | | The state of s | |-------|-----|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | label | PBB | comments | | | | | Load/store Port B map per B. This instruction transfers the 32 Port B map registers to or from memory. If bit 15 of the B-register is clear, the Port B map is loaded from memory starting from the address specified in bits 14-0 of the B-register. If bit 15 of the B-register is set, the Port B map is stored into memory starting at the address specified in bits 14-0 of the B-register. When the load/store operation is complete, the B-register will be incremented by 32 to allow multiple map instructions. An attempt to load any map register when in the protected mode will cause a MEM violation. An attempt to store the Port B map is allowed within the constraints of the write protected memory. Read status register into A. This instruction reads the contents of the MEM status register into the A-register. This instruction can be executed at any time. The format of the MEM status register is given in table 3-1. Read status register into B. This instruction reads the contents of the MEM status register into the B-register and can be executed at any time. The format of the MEM status register is shown in table 3-1. | lahel | PVA | comments | | |-------|-----|----------|--| | ianei | UAV | comments | | Read violation register into A. This instruction reads the contents of the MEM violation register into the A-register and can be executed at any time. The format of the MEM violation register is shown in table 3-2. Read violation register into B. This instruction reads the contents of the MEM violation register into the B-register and can be executed at any time. The format of the MEM violation register is shown in table 3-2. | | 1 | | | 1 | |-------|---|-----|--------|----------| | label | | SJP | m [,I] | comments | Enable System map and jump. This instruction causes the MEM hardware to use the set of 32 map registers, referred to as the System map, for translating all programmed memory references. Prior to enabling the System map, the P-register is set to the effective memory address. As a result of executing this instruction, normal I/O interrupts are held off until the first opportunity following the fetch of the next instruction, unless three or more levels of indirect addressing are used. This instruction will normally generate a MEM violation when executed in the protected mode. In this case, the status of the MEM is not affected and the jump will not occur; however, if the System map is enabled, the instruction is allowed and effectively executes a JMP \*+1, I. Enable System map and jump to subroutine. This instruction causes the MEM hardware to use the set of 32 map registers, referred to as the System map, for translating all programmed memory references. Prior to enabling the System map, the P-register is set one count past the effective memory address. The return address is written into the location specified by m [,I]. As a result of executing this instruction, normal I/O interrupts are held off until the first opportunity following the fetch of the next instruction, unless three or more levels of indirect addressing are used. This instruction will normally generate a MEM violation when executed in the protected mode. In this case, the status of the MEM is not affected and the jump will not occur; however, if the System map is enabled, the instruction is allowed and effectively executes a JSB \*+1,I. | 1 | | | | |-------|-----|--------|----------| | label | SSM | m [,I] | comments | | | | 1 7 7 | | Store status register in memory. This instruction stores the 16-bit contents of the MEM status register into the addressed memory location. The status register contents are not altered. This instruction is used in conjunction with the JRS instruction to allow easy processing of interrupts, which always select the System map (if the MEM is enabled). The format of the MEM status register is listed in table 3-1. This instruction can cause a MEM violation only if write protection rules are violated. | | 1 | | <br>· . | |-------|-----|----------|---------| | label | SYA | comments | | Load/store System map per A. This instruction transfers the 32 System map registers to or from memory. If bit 15 of the A-register is clear, the System map is loaded from memory starting from the address specified in bits 14-0 of the A-register. If bit 15 of the A-register is set, the System map is stored into memory starting at the address specified in bits 14-0 of the A-register. When the load/store operation is complete, the A-register will be incremented by 32 to allow multiple map instructions. Note: If not in the protected mode, the MEM provides no protection against altering the contents of maps while they are currently enabled. An attempt to load any map in the protected mode will cause a MEM violation. An attempt to store the System map is allowed within the constraints of write protected memory. Load/store System map per B. This instruction transfers the 32 System map registers to or from memory. If bit 15 of the B-register is clear, the system map is loaded from memory starting from the address specified in bits 14-0 of the B-register. If bit 15 of the B-register is set, the System map is stored into memory starting at the address specified in bits 14-0 of the B-register. When the load/store operation is complete, the B-register will be incremented by 32 to allow multiple map instructions. Note: If not in the protected mode, the MEM provides no protection against altering the contents of maps while they are cur- rently enabled. An attempt to load any map in the protected mode will cause a MEM violation. An attempt to store the System map is allowed within the constraints of write protected memory. Enable User map and jump. This instruction causes the MEM hardware to use the set of 32 map registers, referred to as the User map, for translating all programmed memory references. Prior to enabling the User map, the P-register is set to the effective memory address. As a result of executing this instruction, normal I/O interrupts are held off until the first opportunity following the fetch of the next instruction, unless three or more levels of indirect addressing are used. If the User map is already enabled, the instruction defaults to JMP \*+1,I. This instruction will normally generate a MEM violation when executed in the protected mode. In this case, the status of the MEM is not affected and the jump will not occur; however, if the System map is enabled, the instruction is allowed. Enable User map and jump to subroutine. This instruction causes the MEM hardware to use the set of 32 map registers, referred to as the User map, for translating all programmed memory references. Prior to enabling the User map, the P-register is set one count past the effective memory address. The return address is written into the location specified by m [,I]. As a result of executing this instruction, normal I/O interrupts are held off until the first opportunity following the fetch of the next instruction, unless three or more levels of indirect addressing are used. If the User map is already enabled, the instruction defaults to JMP \*+1,I. This instruction will normally generate a MEM violation when executed in the protected mode. In this case, the status of the MEM is not affected and the jump will not occur; however, if the System map is enabled, the instruction is allowed. | label | TISA | comments | |-------|------|----------| | | 0011 | comments | Load/store User map per A. This instruction transfers the 32 User map registers to or from memory. If bit 15 of the A-register is clear, the User map is *loaded* from memory starting from the address specified in bits 14-0 of the A-register. If bit 15 of the A-register is set, the User map is *stored* into memory starting at the address specified in bits 14-0 of the A-register. When load/store operation is complete, the A-register will be incremented by 32 to allow multiple instructions. Note: If not in the protected mode, the MEM provides no protection against altering the contents of maps while they are currently enabled. An attempt to load any map in the protected mode will cause a MEM violation. An attempt to store the User map is allowed within the constraints of write protected memory. Load/store User map per B. This instruction transfers the 32 User map registers to or from memory. If bit 15 of the B-register is clear, the User map is loaded from memory starting from the address specified in bits 14-0 of the B-register. If bit 15 of the B-register is set, the User map is stored into memory starting at the address specified in bits 14-0 of the B-register. When the load/store operation is complete, the B-register will be incremented by 32 to allow multiple map instructions. Note: If not in the protected mode, the MEM provides no protection against altering the contents of maps while they are currently enabled. An attempt to load any map in the protected mode will cause a MEM violation. An attempt to store the User map is allowed within the constraints of write protected memory. Cross compare A. This instruction compares the contents of the A-register with the contents of the addressed memory location. If the two 16-bit words are not identical, the next instruction is skipped; i.e., the P-register advances two counts instead of one count. If the two words are identical, the next instruction is executed. Neither the A-register nor memory cell contents are altered. This instruction uses the alternate program map for the read operation. If neither the System map nor the User map is enabled (i.e., MEM is disabled), then a compare directly with physical memory occurs. This instruction will cause a MEM violation only if read protection rules are violated. Cross compare B. This instruction compares the contents of the B-register with the contents of the addressed memory location. If the two 16-bit words are not identical, the next instruction is skipped; i.e., the P-register advances two counts instead of one count. If the two words are identical, the next instruction is executed. Neither the B-register contents nor memory cell contents are altered. This instruction uses the alternate map for the read operation. If neither the System map nor the User map is enabled (i.e., MEM is disabled), then a direct compare with physical memory occurs. This instruction will cause a MEM violation only if read protection rules are violated. | Ì | | | | |-------|-----|--------|----------| | label | XLA | m [,I] | comments | Cross load A. This instruction loads the contents of the specified memory address into the A-register. The contents of the memory cell are not altered. This instruction uses the alternate program map to fetch the operand. If the MEM is currently disabled, then a load directly from physical memory occurs. This instruction will cause a MEM violation only if read protection rules are violated. | label | XLB | m [,I] | comments | |-------|-----|--------|----------| Cross load B. This instruction loads the contents of the specified memory address into the B-register. The contents of the memory cell are not altered. This instruction uses the alternate program map to fetch the operand. If the MEM is currently disabled, then a load directly from physical memory occurs. This instruction will cause a MEM violation only if read protection rules are violated. | label | XMA | comments | |-------|-----|----------| Transfer maps internally per A. This instruction transfers a copy of the entire contents (32 map registers) of the System map or the User map to the Port A map or the Port B map as determined by the control word in the A-register, as follows: | Bit No. | Significance | |---------|----------------------------------| | 15 | 0 = System map<br>1 = User map | | 0 | 0 = Port A map<br>1 = Port B map | (Bits 14-1 are ignored) This instruction will always cause a MEM violation when executed in the protected mode. | label | XMB | comments | |-------|-----|----------| Transfer maps internally per B. This instruction transfers a copy of the entire contents (32 map registers) of the System map or the User map to the Port A map or the Port B map as determined by the control word in the B-register, as follows: | Bit No. | Significance | | |---------|----------------------------------|--| | 15 | 0 = System map<br>1 = User map | | | 0 | 0 = Port A map<br>1 = Port B map | | (Bits 14-1 are ignored) This instruction will always generate a MEM violation when executed in the protected mode. | label | XMM | comments | | |-------|-----|----------|--| Transfer map or memory. This instruction transfers a number of words either from sequential memory locations to sequential map registers or from maps to memory. Bits 0-9 of memory correspond to 0-9 of the map and bits 14 and 15 of memory relate to bits 10 and 11 of the map. The A-register points to the first register to be accessed and the B-register points to the starting address of the table in memory. Maps are addressed as contiguous space and a wraparound count from 127 to 0 can and will occur. It is the programmer's responsibility to avoid this error. The X-register indicates the number of map registers to be transferred. A positive number in X will cause the maps to be loaded with the corresponding data from memory. A negative (two's complement) number in X will cause the maps to be stored into the corresponding memory locations. The instruction is interruptible after each group of 16 registers has been transferred. A, B and X are then reset to allow re-entry at a later time. The X-register will always be zero at the completion of the instruction; A and B will be advanced by the number of registers moved. An attempt to load any map register in Protected Mode will generate a MEM violation. An attempt to store map registers is allowed within the constraints of Write Protected memory. | label | XMS | comments | |-------|-----|----------| Transfer maps sequentially. This instruction transfers a number of words to sequential map registers. The A-register points to the first register to be accessed and the B-register is the base quantity (page number). The X-register indicates the number of map registers to be affected. A positive quantity will cause the word found in the page number to be used as a base quantity to be loaded into the first register. The next register will be loaded with the base quantity plus one, and so forth up to the number of registers. Bits 0-9, 14 and 15 are used as described in XMM. An attempt to load any map register in Protected Mode will generate a MEM violation. An attempt to store map registers is allowed within the constraints of Write Protected memory. Cross store A. This instruction stores the contents of the A-register into the addressed memory location. The previous contents of the memory cell are lost; the A-register contents are not altered. This instruction uses the alternate program map for the write operation. If the MEM is currently disabled, then a store directly into physical memory occurs. This instruction will always cause a MEM violation when executed in the protected mode. Cross store B. This instruction stores the contents of the B-register into the addressed memory location. The previous contents of the memory cell are lost; the B-register contents are not altered. This instruction uses the alternate program map for the write operation. If the MEM is currently disabled, then a store directly into physical memory occurs. This instruction will always cause a MEM violation when executed in the protected mode. #### 3-27. HP 1000 FENCE REGISTERS There are two separate fences available on the HP 1000 M, E and F-Series Computers: the memory protect fence and the base page fence. The HP 1000 L-SERIES Computer has a memory protect fence. The memory protect fence allows you to select a block of memory which will be protected against alteration by any programmed instruction. The memory protect fence register (which specifies the upper bound of the protected area) is loaded from the A- or B-register by an OTA or OTB instruction. See the appropriate hardware manual for specific details on the memory protect fence. The base page fence is only available in HP 1000 M, E and F-Series computers which have the Dynamic Mapping System. This fence specifies which part of the base page is mapped. This determines where shared memory is separated from reserved memory on the base page. The base page fence register is loaded from the A- or B-register by an LFA or LFB instruction. Instructions which modify the fence registers cannot be executed while the computer is in the protected mode. # 3-28. HP 1000 M, E, F-SERIES INSTRUCTION REPLACEMENTS The RTE-L system library contains software substitutions for all the HP 1000 M, E and F-Series CPU instructions that are not included in the HP 1000 L-SERIES instruction set except for the optional DMS instruction set which is not simulated on the HP 1000 L-SERIES hardware. These instruction replacements should enable most user programs written in assembly language to be transported from a HP 1000 M, E and F-Series computer to a HP 1000 L-SERIES by simply editing those instruction mnemonic codes into the JSB .<mnemonic> format for the system library routines in RTE-L. If the user should happen to code an instruction that is not valid for the L-SERIES hardware, the Assembler will not report this fact as an error. The Assembler assembles the full HP 1000 instruction set. The L-SERIES instruction set is a subset of the HP 1000 instruction set. (See Appendix F for a summary of the valid instruction sets for the M, E, F and L-SERIES computers.) Since neither the Assembler nor the Loader will report unimplemented instructions the L-SERIES processor will trap and report as an error any instruction that is not valid for its instruction set. The following error will be reported on the system console: Name ABORTED UI Address where: Name is the name of the program and Address is the address of the offending instruction. ## 3-29. REPLACEMENT FORMATS The name of the software subroutine is formed by preceding the instruction mnemonic with a period (decimal point). The calling sequence is transformed as shown in Figure 3-4. All instructions that are recoded to use the software implementation must be declared as external to the program. ``` 1-word instructions: LABEL XYZ COMMENTS is edited to --> LABEL JSB .XYZ COMMENTS 2-word instructions: LABEL XYZ <operand> COMMENTS is edited to --> LABEL JSB . XYZ COMMENTS DEF <operand> 3-word instructions (CBT, CMW, MBT, MVW): LABEL MBT <operand> COMMENTS is edited to --> LABEL JSB .MBT COMMENTS DEF <operand> DEC 0 3-word instructions (CBS, SBS, TBS): LABEL CBS coperand 1> comments is edited to --> LABEL JSB .CBS COMMENTS DEF <operand 1> DEF <operand 2> ``` Figure 3-4. HP 1000 M, E, F-Series Instruction Replacement Formats .DSY .XAX .XAY .XBX .XBY .LAX .LAY .LBX | REPLACEMENTS | ONE WORD | TWO WORD | (2 operand) (1 operand) | |---------------------------------------------------------------------------------------------------------------|------------------------|------------------------|-------------------------| | The following list represents the HP 1000 M, E, F-Series instructions that have software substitutions in the | .CAX .FIX<br>.CAY .FLT | .ADX .LBY | .CBS .CBT | | RTE-L system library. | . CBX | .ADY .LDX | .SBS .CMW<br>.TBS .MBT | | | .CBY .ISX<br>.CXA .ISY | .FAD<br>.FDV .SAX | . MVW | | | .CXB<br>.CYA .LBT | .FMP .SAY<br>.FSB .SBX | | | | .CYB<br>.SBT | .SBY<br>.JLY .STX | | | | .DSX .SFB | .JPY .STY | | HP 1000 M, E, F-SERIES SOFTWARE REPLACEMENTS 3-30. THREE WORD # **PSEUDO INSTRUCTIONS** The pseudo instructions control the Assembler and its listed output, establish program relocatability, and define program linkage as well as specify various types of constants, blocks of memory, and labels used in the program. # 4-1. ASSEMBLER CONTROL The Assembler control pseudo instructions establish and alter the contents of the base page and program location counters, and terminate assembly processing. Labels may be used but they are ignored by the Assembler. The NAM statement, which must be the first statement in an Assembler source program, includes optional parameters defining the program type, priority, and time values. This information is used to fill in the NAM record of the program module (see Appendix H for the format of the NAM record). NAM name [,type,pri,res,mult,hr,min,sec,msec id] name is the name of the program. type (RTE-IV) is the program type. (Defaults to 3 if not specified): - 0 system program or driver. - 1 memory resident. - 2 real-time disc resident. - 3 background disc resident. - 4 background disc resident with Table Area II access. - 5 program segment (RT or BG). - 6 library, reentrant or privileged subroutines (note that if called by a memory resident program, these routines are relocated into the Memory Resident Library. After memory resident loading they become Type 7). - 7 library, utility subroutines (appended to calling program). - 8 if program is a main, it is deleted from the system, or, - if program is a subroutine, it is used to satisfy any external references during generation; however, it is not loaded in the relocatable library area of the disc. - 13 (Table Area II) system entry points that contain pointers and system values that are defined at - generation. Table Area II is a combination of these relocated Type 13 modules and system tables that are built by the generator. - 14 same as Type 6, but automatically included in the Memory Resident Library. They become Type 7 after memory resident loading. - 15 (Table Area I) system entry points that must be included in the system and user maps. Table Area I is a combination of these relocated Type 15 modules and I/O tables that are built by the generator. - 30 Subsystem Global Area (SSGA). Note: In some cases the primary type code (i.e., 1, 2, 3, 4) may be expanded by adding 8, 16, or 24 to the number. These expanded types allow such features as: access to real-time COMMON by background programs, and access to SSGA. #### CAUTION The primary type code of a main program and its segments must not be changed because the relationship between the program and its segments would be lost. type (RTE-L) is the program type. The only significant program types in RTE-L are: - 5 program segment (RT or BG). The RTE-L generator will not load segmented programs. They must be loaded on-line. - 6 library, reentrant or privileged subroutines. The user may direct the generator to relocate the program into the Memory Resident Library. If so, programs that reference this code will not have the subroutine appended to it, they will use the memory resident code. If not loaded in the Memory Resident Library, a copy of the code will be appended to each referencing program. - 7 library, utility subroutines (appended to calling program.) If the routine is included in the System Relocation phase of a generation, all entry points are not retained in the snap file. All other program types are not significant in RTE-L. Determining whether the program is Real-Time or Background is made a load time by the appropriate LOADR or GENERATOR command. pri is the priority (1 to 32767, set to 99 if not given). res is the resolution code mult is the execution multiple hr is hours min is minutes sec is seconds msec is tens of milliseconds id comments field (separated from operand by a space) #### COMMENTS The parameters of the NAM statement, beginning with type and ending with msec, are separated by commas. A blank space within the parameter field will terminate that field and cause the Assembler to recognize the next entry as the comment field (id). The first parameter must be separated from the program name by a comma. The parameters are optional, but to specify any particular parameter, those preceding it must also be specified, as shown below: NAM EX1,2,99,1,999,10,20,30,30 NAM EX2,1,10 THIS IS ID OF PROGRAM. Starting immediately after the first blank, the identifier field is placed in the relocatable NAM record following the parameters (a blank space separates the parameter and comment fields). In the following example a part number is shown in the comments field of the second line: NAM PRGRM THIS IS ON RELOC. RECORD NAM MYNAM,1,9,4 25117-80345B The identifier (comments) field (id) can be a maximum of 73 characters due to the restriction of the source statement size. The identifier will be truncated after column 80. ORB defines the portion of a relocatable program that must be assigned to the base page by the Assembler. The Label field (if given) is ignored, and the statement requires no operand. All statements that follow the ORB statement are assigned contiguous locations in the base page. Assignment to the base page terminates when the Assembler detects an ORG, ORR, or END statement. When more than one ORB is used in a program, each ORB causes the Assembler to resume assigning base page locations at the address following the last assigned base page location. An example is shown in figure 4-1. An ORB statement in an absolute program has no significance and is flagged as an error. The ORG statement defines the origin of an absolute program, or the origin of subsequent sections of absolute or relocatable programs. An absolute program must begin with an ORG statement. The operand m, must be a decimal or octal integer specifying the initial setting of the program location counter. | NAM PROG | ASSIGN ZERO AS RELATIVE STARTING LOCATION FOR PROGRAM PROG. | |---------------|-------------------------------------------------------------| | • | | | ORB | ASSIGN ALL FOLLOWING STATEMENTS TO BASE PAGE. | | IAREA BSS 100 | | | | | | • | A CONTRACTOR MATCH BROOKEN | | ORR | CONTINUE MAIN PROGRAM. | | • | | | ORB | RESUME ASSIGNMENT AT NEXT | | J CKB | AVAILABLE LOCATION IN BASE PAGE. | | | ,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,, | | | | | ORR | CONTINUE MAIN PROGRAM. | Figure 4-1. ORB Example ORG statements may be used elsewhere in the program to define starting addresses for portions of the object code. For absolute programs the Operand field, m, may be any expression. For relocatable programs, m must not be common relocatable or absolute. An expression is evaluated modulo $2^{15}$ . Symbols must be previously defined. All instructions following an ORG are assembled at consecutive addresses starting with the value of the operand. ORR resets the program location counter to the value existing when an ORG or ORB instruction was encountered. An example is shown in figure 4-2. More than one ORG statement may occur before an ORR is used. If so, when the ORR is encountered, the program location counter is reset to the value it contained when the first ORG of the string occurred. An example is shown in figure 4-3. If a second ORR appears before an intervening ORG or ORB the second ORR is ignored. ``` NAM RSET SET PLC TO VALUE OF ZERO, ASSIGN FIRST ADA RSET AS NAME OF PROGRAM. ADA CTRL ASSUME PLC AT FIRST+2280. ORG FIRST+2926 SAVE PLC VALUE OF FIRST+2280 AND SET PLC TO FIRST+2926. JMP EVEN+1 ASSUME PLC AT FIRST+3004 ORR RESET PLC TO FIRST+2280. ``` Figure 4-2. ORR Example (with Single ORG) Figure 4-3. ORR Example (with Multiple ORGs) The IFN and IFZ pseudo instructions cause the inclusion of instructions in a program provided that either an "N" or "Z", respectively, is specified as a parameter for the ASMB control statement.† The IFN or IFZ instruction precedes the set of statements that are to be included. The pseudo instruction XIF serves as a terminator. If XIF is omitted, END acts as a terminator to both the set of statements and the assembly. All source language statements appearing between the IFN and the XIF pseudo instructions are included in the program if the character "N" is specified on the ASMB control statement. All source language statements appearing between the IFZ and XIF pseudo instructions are included in the program if the character "Z" is specified on the ASMB control statement. Figure 4-4. IFN/XIF and IFZ/XIF Example When the particular letter is not included on the control statement, the related set of statements appears on the Assembler output listing but is not assembled. Any number of IFN-XIF and IFZ-XIF sets may appear in a program, however, they may not overlap. An IFZ or IFN intervening between an IFZ or IFN and the XIF terminator results in a diagnostic being issued during compilation; the second pseudo instruction is ignored. Both IFN-XIF and IFZ-XIF pseudo instructions may be used in the program; however, only one type will be selected in a single assembly. Therefore, if both characters "N" and "Z" appear in the control statement, the character which is listed last will determine the set of coding that is to be assembled. Some examples are shown in figures 4-4 and 4-5 In figure 4-4, the program TRAVL will perform computations involving either or neither CAR or PLANE considerations depending on the presence or absence of Z or N parameters in the Control Statement. In figure 4-5, the program WAGES computes a weekly wage value. Overtime consideration will be included in the program if "Z" is included in the parameters of the Control Statement. Figure 4-5. IFZ/XIF Example <sup>†</sup>See "Assembly Options" in Section I of this manual. The REP pseudo instruction causes the repetition of the statement immediately following it a specified number of times. The statement following the REP in the source program is repeated n times. The n may be any absolute expression. Comment lines (indicated by an asterisk in character position 1) are not repeated by REP. If a comment follows a REP instruction, the comment is ignored and the instruction following the comment is repeated. A label specified in the REP pseudo instruction is assigned to the first repetition of the statement. A label should not be part of the instruction to be repeated; it would result in a doubly defined symbol error. #### Example: TRIPL REP 3 ADA DATA The above source code would generate the following: | | CLA | | Clear the A-Register; | |-------|-----|------|---------------------------| | | | | the content of DATA is | | TRIPL | ADA | DATA | tripled and stored in the | | | ADA | DATA | A-Register. | | | ADA | DATA | | ## Example: FILL REP 100B NOP The example above loads $100_8$ memory locations with the NOP instruction. The first location is labeled FILL. #### Example: REP 2 MPY DATA The above source code would generate the following: | | DATA<br>DATA | | | |-----|--------------|----------|--| | END | [m] | comments | | This statement terminates the program; it marks the physical end of the source language statements. The Operand field, m, may contain a name appearing as a statement label in the current program or it may be blank. If this is a main program m must be specified. If a name is entered, it identifies the entry point to the module. If the Operand field is blank, the Comments field must be blank also, otherwise, the Assembler attempts to interpret the first five characters of the comments as the transfer address symbol. The label field of the END statement is ignored. # 4-2. OBJECT PROGRAM LINKAGE Linking pseudo instructions provides a means for communication between a main program and its subroutines or among several subprograms that are to be run as a single program. These instructions may be used only in a relocatable program. The Label field of this class is ignored in all cases. The Operand field is usually divided into many subfields, separated by commas. In the case of the COM pseudo instruction, the first space not preceded by a comma or a left parenthesis terminates the entire field. COM reserves a block of storage locations that may be used in common by several subprograms. Each name identifies a segment of the block for the subprogram in which the COM statement appears. The sizes are the number of words allotted to the related segments. The size is specified as an octal or decimal integer. If the size is omitted, it is assumed to be one. Any number of COM statements may appear in a subprogram. Storage locations are assigned contiguously; the length of the block is equal to the sum of the lengths of all segments named in all COM statements in the subprogram To refer to the common block, other subprograms must also include a COM statement. The segment names and sizes may be the same or they may differ. Regardless of the names and sizes specified in the separate subprograms, there is only one common block for the combined set. It has the same relative origin; the content of the nth word or common storage is the same for all subprograms. An example is shown in figure 4-6. The LDA instructions in the two subprograms each refer to the same location in common storage, location 7. ``` PROG1 COM ADDR1(5),ADDR2(10),ADDR3(10) LDA ADDR2+1 PICK UP SECOND WORD OF SEGMENT ADDR2+1 END PROG2 COM AAA(2),AAB(2),AAC,AAD(20) LDA AAD+1 PICK UP SECOND WORD OF SEGMENT ADD+1. ``` # Organization of common block: | PROG1 | PROG2 | Common | |-------|-------|---------------| | name | name | Block | | | | | | ADDR1 | AAA | (location 1) | | | | (location 2) | | | AAB | (location 3) | | | | (location 4) | | | AAC | (location 5) | | ADDR2 | AAD | (location 6) | | | | (location 7) | | | | (location 8) | | | | (location 9) | | | | (location 10) | | | | (location 11) | | | | (location 12) | | | | (location 13) | | | | (location 14) | | | | (location 15) | | ADDR3 | | (location 16) | | | | (location 17) | | | | (location 18) | | | | (location 19) | | | | (location 20) | | | | (location 21) | | | | (location 22) | | | | (location 23) | | | | (location 24) | | | | (location 25) | | | | | Figure 4-6. COM Examples The segment names that appear in the COM statements can be used in the Operand fields of DEF, ABS, EQU, ENT or any memory reference statement; they may not be used as labels elsewhere in the program. The loader establishes the origin of the common block; the origin cannot be set by the ORG pseudo instruction. All references to the common area are relocatable. Two or more subprograms may declare common blocks that differ in size. The subprogram that defines the largest block must be the first submitted for loading. # 4-3. PROGRAM AND SYSTEM COMMON All common specified in an assembly language program with the COM statement is named common which is often called "labeled" common. The use of system or program common is specified at load time using the appropriate loader command. Under RTE operating systems other than RTE-L the generator will load those programs using common, so that the common is system common. Under the RTE-L operating system, by default the generator will load those programs using common, so that the common is program common. If the user wants to use system common, he should use the LOD statement with the appropriate loader command. See the section on RTE-L PSEUDO INSTRUCTIONS and the RTE-L RE-LOCATING LOADER REFERENCE MANUAL for specific details on the use of the LOD instruction and loader commands. The user can optionally specify to the RTE-L generator that the common be system common instead of program common. Unlike program common, system common is shared by all other programs on the system. This implies a great deal of coordination. Any program that uses system common should know how all other programs use system common. Only in this fashion can the programmer ensure that his data in system common will be secure. If the programmer does not know the interaction process of other programs who use system common, he should use program common. ENT defines entry points to the program or subprogram. Each name is a symbol that is assigned as a label for some machine operation in the program. Entry points allow another subprogram to refer to this subprogram. All entry points must be defined in the program. Symbols appearing in an ENT statement may not also appear in an EXT statement in the same subprogram. Labels defined as absolute by EQU statements or defined by COM statements may be declared as entry points. | EXT | name <sub>1</sub> [,name <sub>2</sub> ,,name <sub>n</sub> ] | comments | |-----|-------------------------------------------------------------|----------| This instruction designates labels in other subprograms that are referenced in this subprogram. The symbols must be defined as entry points by the other subprograms. The symbols defined in the EXT statement may appear in memory reference statements, certain I/O statements or EQU or DEF pseudo instructions. An external symbol may be used with a + or - offset or specified as indirect. References to external locations are processed by the loader as indirect addresses linked through the base page or in some cases through a current page link. Symbols appearing in EXT statements may not also appear in ENT or COM statements in the same subprogram. The label field is ignored. Examples of the use of EXT and ENT are shown in figures 4-7 through 4-10. The RPL pseudo instruction is used to define a code replacement record for the RTE system generator or RTE relocating loader. | label | RPL | m | comments | |-------|-----|---|----------| The instructions to be replaced must be of the form = JSB SUB where SUB is an external reference. The JSB SUB will be replaced by the octal value of the RPL definition whenever it is encountered by the generator or loader. Examples are shown in figure 4-11. ``` PROGA NOP LDA SAMD SAMD AND SAND ARE REFERENCED IN PROGA, BUT ARE ACTUALLY LOCATIONS IN PROGB. JMP SAND EXT SAMD, SAND ENT PROGA END PROGB NOP SAMD OCT 767 SAND STA SAMD ENT SAMD, SAND JSB PROGA EXT PROGA END ``` Figure 4-7. ENT/EXT Examples ``` EXT BUF,PTR . . . LDA BUF+1 EXTERNAL WITH + OR - OFFSET. STA PTR,I EXTERNAL INDIRECT. ``` Figure 4-8. EXT with Offset ``` ENT CHAN, CMLBL . . . CHAN EQU 12B COM CMLBL (20) ``` Figure 4-9. ENT in COMmon and ENT Defining An External I/O Reference ``` ASMB, R, B, L NAM MAIN × 30 DECLARE CHAN1, CHAN2 AS ENTRY POINTS × ENT CHAN1, CHAN2 EXT OUTPT, INPUT START JSB INPUT INPUT A CHARACTER JSB OUTPT OUTPUT TO DEVICE 2 READ SWITCH REGISTER LIA 1B IS BIT 15 ON? SSA HLT 55B YES, HALT JMP START DO ANOTHER ONE × ж DEFINE THE I/O CHANNELS FOR THE DRIVERS INPUT, OUTPT BY × SETTING THE LABELS CHAN1, CHAN2 EQUIVALENT TO THE ABSOLUTE LOCATIONS 10,11. CHAN1 EQU 10B CHAN2 EQU 11B END START ``` ``` ASMB, R, B, L NAM IOPRG Х SUBROUTINE ENTRY POINTS ENT INPUT, OUTPT Х DECLARE I/O CHANNELS TO BE EXTERNAL EXT CHAN1, CHAN2 ж ж INPUT SUBROUTINE 20 INPUT NOP SET CONTROL ON CHANNEL 1 STC CHAN1, C SFS CHAN1 JMP X-1 WAIT ON FLAG LIA CHAN1. LOAD WORD JMP INPUT, I RETURN × ж OUTPUT SUBROUTINE OUTPT NOP OTA CHAN2 OUTPUT WORD STC CHAN2, C STROBE TO DEVICE SFS CHAN2 JMP ×-1 RETURN JMP OUTPT, I END ``` Figure 4-10. EXT, ENT for I/O Channel Figure 4-11. Label RPL Octal Value The relocation of the program would result in the following: ``` Note that the instruction value is 105000 instead of 114XXX. Note that the instruction value is 105100 instead of 114XXX. ``` # 4-4. ADDRESS AND SYMBOL DEFINITION The pseudo operations in this group assign a value, a word address, or a byte address to a symbol which is used as an operand elsewhere in the program. The address definition statement generates one word of memory as a 15-bit address which may be used as the object of an indirect address found elsewhere in the source program. The symbol appearing in the label is that which is referenced; it appears in the Operand field of a Memory Reference instruction. The operand field of the DEF statement may be any positive expression in an absolute program; in a relocatable program it may be a relocatable expression or an absolute expression with a value of less than 2000<sub>8</sub>. Symbols that do appear in the Operand field may appear as operands of EXT or COM statements, in the same subprogram and as entry points in other subprograms. The expression in the Operand field may itself be indirect and make reference to another DEF statement elsewhere in the source program. Some examples are shown in figure 4-12. The DEF statement provides the necessary flexibility to perform address arithmetic in programs which are to be assembled in relocatable form. Relocatable programs should not modify the operand of a memory reference instruction. Figure 4-13 illustrates what not to do. If TBL and LDTBL are in different pages, the Loader processes TBL as an indirect address linked through the base page. The ISZ erroneously increments the Loader-provided link to the base page rather than the value of TBL. Assuming that the loader assigns the absolute locations shown in figure 4-14, the ISZ will index the contents of location 2000<sub>8</sub> which is a LDA 700,I, and change it to LDA 701,I. Now we will use whatever happens to be in 701 rather than the link we intended to use which is in 700. We change the *link* instead of its *contents*. Figure 4-13. Example of Incorrect Address Modification | | PROGN<br>SINE, SQRT | ZERO-RELATIVE START OF PROGRAM. | |-----|---------------------|------------------------------------------------------| | COM | SCMA(20), S | SCMB(50) | | | | EXECUTE SINE ROUTINE | | | , | PICK UP COMMON WORD INDIRECTLY. | | | | SCMA IS A 15-BIT ADDRESS. | | | | GET SQUARE ROOT USING TWO-LEVEL INDIRECT ADDRESSING. | | , | SQRT<br>PROGN | SQRT IS A 15-BIT ADDRESS. | Figure 4-12. DEF Examples | INS | STRUCTI | ON | PAGE | ABSOLUTE<br>LOCATION<br>OF CODE | OPCODE | OPERAND<br>(PAGE) &<br>LOCATION | |------------------------|--------------------------|-------|------|---------------------------------|---------------|---------------------------------| | (Loader-a<br>link on b | ssigned ir<br>pase page) | | (0) | (700) | DEF<br>• | 4000 | | LDTBL | LDA | TBL | (1) | (2000) | LDA<br>• | (0) 700 (1) | | | ISZ | LDTBL | (1) | (3000) | ·<br>ISZ<br>· | (1) 2000 | | TBL | BSS | 100 | (2) | (4000) | BSS | | Figure 4-14. Loader-Assigned Locations for Figure 4-13 The example shown in figure 4-15 assures correct address modification during program execution. Assume that the sequence shown in figure 4-15 is assigned (by the loader) the absolute locations shown in figure 4-16. The LDA 2000,I picks up the *contents* of the location pointed to by ITBL (location $4000_8$ ). The ISZ 2000 indexes the pointer DEF 4000 to point to 4001. The next LDA will reference location 4001, DEF TBL+1. This is what we intend. | label | ABS | m | comments | |-------|-----|---|----------| ABS defines a 16-bit absolute value to be stored at the location represented by the label. The Operand field, m, may be any absolute expression; a single symbol must be defined as absolute elsewhere in the program. Examples are shown in figure 4-17. | ITBL DEF | | |-----------|----------| | LDTBL LDA | \ ITBL,I | | | | | • | | | • | | | I S Z | ITBL | | | | | | | | TBL BSS | 5 100 | | | , 100 | | | | | | | Figure 4-15. Example of Correct Address Modification | IN | STRUCT | ON | PAGE | ABSOLUTE<br>LOCATION<br>OF CODE | OPCODE | OPERAND<br>(PAGE) &<br>LOCATION | |------|--------|---------|------|---------------------------------|----------|---------------------------------| | ITBL | DEF | TBL | (1) | (2000) | DEF | 4000 | | | LDA | ITBL,I | (1) | (2001) | LDA<br>· | (1) 2000,1 | | | ISZ | ITBL | (1) | (3000) | ISZ<br>• | (1) 2000 | | | TBL | BSS 100 | (2) | 4000 | BSS | | Figure 4-16. Loader-Assigned Locations for Figure 4-15 | АВ | EQU | 35 | | GNS THE VALUE OF 35<br>HE SYMBOL AB | |-----|-----|-------|-----|------------------------------------------------------------------| | M35 | ABS | -AB | M35 | CONTAINS 35. CONTAINS 35. CONTAINS 70. CONTAINS 30. CONTAINS 36. | | P35 | ABS | AB | P35 | | | P70 | ABS | AB+AB | P70 | | | P30 | ABS | AB-5 | P30 | | | P36 | ABS | 36 | P36 | | Figure 4-17. ABS Examples | label | EQU | m | comments | |-------|-----|---|----------| The EQU pseudo operation assigns to a symbol a value other than the one normally assigned by the program location counter. The symbol in the Label field is assigned the value represented by the Operand field. The Operand field may contain any expression. The value of the operand may be common, base page or program relocatable as well as absolute, but it should not be negative. Symbols appearing in the operand must be previously defined in the source program. The EQU instruction may be used to symbolically equate two locations in memory, or it may be used to give a value to a symbol. The EQU statement does not result in a machine instruction. Some examples are shown in figures 4-18 and 4-19. | label | DBL | m | comments | |-------|-----|---|----------| | label | DBR | m | comments | Define Left Byte and Define Right Byte. The DBL and DBR pseudo instructions each generate one word of memory which contains a 16-bit byte address. For DBL, the byte address being defined is the left half (bits 8-15) of word location m; for DBR, it is the right half (bits 0-7). Indirect addressing may not be used. A byte address is defined as two times the word address of the memory location containing the particular byte. If the byte location is the left half of the memory location (bits 8-15), bit 0 of the byte address is clear; if the byte location is the right half of the memory lcoation (bits 0-7), bit 0 of the byte address is set. In an absolute program, m may be any positive expression. In a relocatable program, m may be any absolute expression with a value less than 2008 or any relocatable expression. The generated word may be referenced (via label) in the Operand field of LDA and LDB instructions elsewhere in the source program for the purpose of loading byte addresses into the A- and B-registers. #### CAUTION Care must be taken when using the *label* of a DBL or DBR pseudo instruction as an indirect address elsewhere in the source program. The programmer must keep track of whether he is using word addresses or byte addresses. Figure 4-18. EQU Example ``` NAM STOTB COM TABLA(10) DEFINES A 10 WORD TABLE, TABLA. TABLB EQU TABLA+5 NAMES WORDS 6 THROUGH 10 OF TABLA AS TABLB. LDA TABLB+1 LOADS CONTENTS OF 7TH WORD COMMON INTO A. THE STATEMENT LDA TABLA+6 WOULD PERFORM THE SAME OPERATION NAM REG Α EOU 0 DEFINES SYMBOL A AS 0 (LOCATION EQU 1 OF A-REGISTER), AND SYMBOL B AS 1 (LOCATION OF B-REGISTER). LDA B LOADS CONTENTS OF B-REGISTER INTO A-REGISTER. ``` Figure 4-19. EQU Examples ### Examples: BYT1 DBL WORD1 BYT2 DBR WORD1 ... WORD1 NOP If WORD1 has the relocatable address $2002_8$ , then BYT1 will contain the relocatable value $4004_8$ and BYT2 will contain the relocatable value $4005_8$ . # 4-5. CONSTANT DEFINITION The pseudo instructions in this class enter a string of one or more constant values into consecutive words of the object program. The statements may be named by labels so that other program statements can refer to the fields generated by them. | label | ASC | n, <2n characters> | comments | |-------|-----|--------------------|----------| ASC generates a string of 2n alphanumeric characters in ASCII code into n consecutive words.† One character is right justified in each eight bits; the most significant bit is zero. n may be any expression resulting in an unsigned decimal value in the range 1 through 28. Symbols used in an expression must be previously defined. Anything in the Operand field following 2n characters is treated as comments. If less than 2n characters are detected before the end-of-statement mark, the remaining characters are assumed to be spaces, and are stored as such. The label represents the address of the first two characters. An example is shown in figure 4-20. DEC records a string of decimal constants into consecutive words. The constants may be either integer or real (floating point), and positive or negative. If no sign is specified, positive is assumed. The decimal number is converted to its Figure 4-20. ASC Example binary equivalent by the Assembler. The label, if given, serves as the address of the first word occupied by the constant. A decimal integer must be in the range of $-2^{15}$ to $2^{15}$ -1. It is converted into one binary word and appears as follows: Some examples are shown in figure 4-21. A floating point number has two components, a fraction and an exponent. The exponent specifies the power of 10 by which the fraction is multiplied. The fraction is a signed or unsigned number which may be written with or without a decimal point. The exponent is indicated by the letter E and follows a signed or unsigned decimal integer. The floating point number may have any of the following formats: $$\pm n.n$$ $\pm n.$ $\pm n.$ $nE\pm e$ $\pm n.$ $nE\pm e$ $\pm n.$ $nE\pm e$ The number is converted to binary, normalized (leading bits differ), and stored in two computer words. If either the fraction or the exponent is negative, that part is stored in two's complement form. INT DEC 50,+328,-300,+32768,-32768 causes the following (octal representation) 15 14 INT 0 0 0 0 6 2 0 0 0 1 7 7 3 2 4 1 0 0 0 1 0 0 0 The values $\pm 2^{15}$ ( $\pm 32768$ ) are both converted to $100000_8$ . Figure 4-21. DEC Examples (Integer) are stored as: DEC -.695,400E-4 Figure 4-22. DEC Examples (Floating Point) Figure 4-23. DEC Examples (Floating Point) The floating point number is made up of a 7-bit exponent with sign and a 23-bit fraction with sign. The number must be in the approximate range of $10^{-38}$ to $10^{+38}$ . Examples are shown in figures 4-22 and 4-23. DEX records a string of extended precision decimal constants into consecutive words within a program. Each such extended precision constant occupies three words as shown in figure 4-24. An extended precision floating point number is made up of a 39-bit fraction and sign and a 7-bit exponent and sign. This is the only form used for DEX. All values, whether they be floating point, integer, fraction, or integer and fraction, will be stored in three words as just described. This storage format is basically an extension of that used for DEC, as previously described. Some examples are shown in figure 4-25. Figure 4-24. DEX Memory Format DEY records a string of extended precision decimal constants into consecutive words within a program. Each such extended precision constant occupies four words as shown in Figure 4-24A. A four-word extended precision floating point number is made up of a 55-bit fraction and sign and a 7-bit exponent and sign. This storage format is basically an extension of that used for DEX, as previously defined. Figure 4-24A. DEY Memory Format OCT stores one or more octal constants in consecutive words of the object program. Each constant consists of one to six octal digits (0 to 177777). If no sign is given, the sign is assumed to be positive. If the sign is negative, the two's complement of the binary equivalent is stored. The constants are separated by commas; the last constant is terminated by a space. If less than six digits are indicated for a constant, the number is right justified in the word. A label, if used, acts as the address of the first constant in the string. The letter B must not be used after the constant in the Operand field; it is significant only when defining an octal term in an instruction other than OCT. Some examples are shown in figure 4-26. Figure 4-25. DEX Examples OCT + 0OCT - 2NUM OCT 177,20405,-36 OCT 51,77777,-1,10101 OCT 107642,177077 OCT 1976 OCT -177777 OCT 177B ILLEGAL: CONTAINS DIGIT 9 ILLEGAL : CONTAINS CHARACTER B The above statements are stored as follows: NUM The result of attempting to define an illegal constant is unpredictable Figure 4-26. OCT Examples Define Octal Byte constants. The BYT pseudo instruction generates octal constants in consecutive byte locations of memory. Each constant in the Operand field $(b_1,b_2,\dots b_n)$ consists of one to three octal digits, must be within the range 0 through 377, and may be preceded by a plus (+) or minus (-) sign. If a constant is not signed, it is assumed to be positive. If a constant is negative, the two's complement of the binary equivalent (truncated to eight bits) is stored. If the Operand field contains an odd number of constants, bits 0-7 of the final word generated will be clear (zeros). Since the constants are assumed to be octal, the letter "B" must not be used. Some examples are shown in figure 4-27. ## 4-6. STORAGE ALLOCATION The storage allocation statements reserve a block of memory for data or for a work area. The BSS pseudo operation advances the program or base page location counter according to the value of the operand. The Operand field may contain any expression that results in a positive integer. Symbols, if used, must be previously defined in the program. The label, if given, is the name assigned to the storage area and represents the address of the first word. The initial content of the area set aside by the statement is unaltered by the loader. The EMA pseudo-instruction defines an extended memory area (EMA) where $m_1$ is the EMA size in pages and $m_2$ is the mapping segment (MSEG) size in pages. $m_1$ and $m_2$ must be expressions that evaluate to non-relocatable integers. $m_1$ must be in the range 0 to 1023 inclusive and $m_2$ must be in the range 0 to 31 inclusive. If $m_1$ evaluates to 0 the maximum possible size for EMA will be assigned at dispatch time. If $m_2$ evaluates to 0 the maximum possible size for MSEG will be assigned at load time. The EMA pseudo-instruction may only be used in a relocatable program. Only one EMA pseudo-instruction per program is allowed. An EMA pseudo-instruction must have a label which is the name assigned to the storage area. This label represents the logical address of the first word in the MSEG and is determined at load time. EMA labels may appear in memory reference statements, and in EQU or DEF pseudo-instructions. References to EMA labels are processed as indirect addresses through a base page link at load time. EMA labels may be referenced in other subprograms or segments by declaring them as externals in the other subprograms or segments. They should not be declared as entry points in the program in which they appear. The following restrictions apply to the use of EMA labels: - 1. EMA labels may not be used with an offset. - 2. EMA labels may not be used with indirect. - 3. EMA labels may not appear in an ENT or COM statement in the same subprogram. ALF BYT 50,377,-10,2,-312 causes the following (octal representation): 14 0 15 ALF 0 2 4 3 7 7 7 4 0 0 2 1 0 3 3 0 0 0 Figure 4-27. BYT Examples The following example illustrates the use of a forty page EMA that has a five page MSEG. In the example, the main program calls MMAP to map the third MSEG into its logical address space. Then it stores the value at the start of the third MSEG into the 1028th word of the third MSEG. Then it calls a subroutine to process that element. The subroutine loads the value into the B-register to process it, and then returns to the calling program. Refer to Figure 4-28 for a pictorial explanation of the elements that are being addressed. NAM EMAPR,3 EXT EMASB EXT MMAP **EMALB EMA 40.5** 40 pages of EMA, 5 pages per MSEG ADEMA DEF EMALB D1027 **DEC 1027** \* CALL MMAP TO MAP THIRD MSEG INTO PRO-GRAMS LOGICAL ADDRESS SPACE **EMAPR** JSB MMAP DEF RTN DEF IPGS Offset in pages of MSEG being mapped DEF NPGS Number of pages in MSEG \* STORE FIRST WORD OF THIRD MSEG INTO 1028TH WORD OF THIRD MSEG RTN LDA EMALD First word of MSEG referenced directly LDB ADEMA Use B-Reg to reference 1028th word of MSEG RBL,CLE,SLB,ERB Resolve one indirect LDB 1,I **ADB D1027** STA 1,I Store A-Reg into 1028th word of current MSEG \* JSB PASSING OFFSET ADDRESS TO SUBROUTINE JSB EMASB **DEF D1027** Pass offset address as parameter **IPGS** DEC 10 **NPGS** DEC 5 NAM EMASB,7 External subroutines and segments declare EMA as an external ENT EMASB EXT **EMALB** ADEMA DEF EMALB \* SUBROUTINE ENTRY POINT IS HERE, A-REG IS USED TO COMPUTE ADDRESS **EMASB** NOP > LDA EMASB,I LDA 0,I Get address of offset Get offset value LDB ADEMA RBL,CLE,SLB,ERB LDB 1,I ADA 1 LDB 0,I Add in address of current MSEG start Load 1028th word of current MSEG into B-Reg ISZ **EMASB** JMP EMASB.I Return to caller END Figure 4-28. EMA Logical Memory for Example Program # 4-7. RTE-L PSEUDO INSTRUCTIONS The Assembler recognizes two new pseudo instructions for use in the RTE-L operating system. Under RTE-IV operating systems the information records that are produced by these two pseudo-instructions are ignored by the RTE-IV loader and generator. Two useful pseudo instructions are available to aid in the loading and generation process of RTE-L programs and systems. The LOD pseudo instruction allows the programmer to specify LOADR instructions at the program code level rather than at load time. The GEN pseudo instruction can help simplify RTE-L system generations. With the GEN record the user can set up interface and device driver defaults into the program (i.e. driver) code which are then put into files and can be accessed by the generator. This process simplifies the preparation for generation by relieving the need of getting and specifying all of the parameters needed for the Interface Table (IFT) and Device Tables (DVT). The use of LOD and GEN pseudo instructions does not directly affect the size of a relocatable program or driver. They occupy no code space. #### 4-8. LOD STATEMENT | | | | 1 | |-------|-----|----------------------------|----------| | label | LOD | n, < ASCII Loader Command> | comments | LOD passes to the RTE-L loader the specified LOADR command. The first operand, n specifies the number of words occupied by the second operand. One character is right justified in each eight bits; the most significant bit is zero. n may be any expression resulting in an unsigned decimal value in the range 1 through 28. Symbols used in an expression must be previously defined. Anything in the operand field following 2n characters is treated as comments. If an odd number of characters is present or less than 2n characters are detected before the end of the operand field, the remaining characters are assumed to be spaces, and are stored as such. Examples are shown in Figure 4-29. The LOD command enables the user to programmatically give commands to LOADR. For example a Real-Time program is to be loaded with a priority of 10, containing 3 segments, and the user wants to minimize Base Page links. A typical LOADR scenario might look like the following: (user responses are underlined). #### RU,LOADR LOADR: RTIME LOADR: PRIORITY, 10 LOADR: SGMENTS,3 LOADR: CPAGE LOADR: RE, XEXMPL LOADR: <u>END</u> If this program is to be loaded in the same fashion EVERYTIME, then the user may wish to "hard-code" the LOADR commands into his program with the LOD command. See Figure 4-29 for examples. After coding in the LOADR command the user has only to do the following to accomplish the same tasks that were previously done interactively. RU,LOADR,,%EXMPL See the RTE-L RELOCATING LOADER REFERENCE MANUAL for specific details on LOADR commands. | ASMB,L,C | | |----------|---------------| | NAM | EXMPL | | LOD | 3,RTIME | | LOD | 6,PRIORITY,10 | | LOD | 5,SGMENTS,3 | | LOD | 3,CPAGE | Figure 4-29. LOD Pseudo-Instruction Example ### 4-9. GEN STATEMENT GEN passes interface or device driver default parameters to the generator to be used in the process of system generation. The first operand, n specifies the number of words filled by the second operand. One character is right justified in each eight bits; the most significant bit is zero. n may be any expression resulting in an unsigned decimal value in the range 1 through 28. Symbols used in an expression must be previously defined. Anything in the operand field following 2n characters is treated as comments. If an odd number of characters is present or less than 2n characters are detected before the end of the operand field, the remaining characters are assumed to be spaces, and are stored as such. Examples are shown in Figure 4-30. The GEN statement simplifies the process of DVT and IFT inputs to the generator. If the user is writing his own interface or device driver, in the actual driver code, defaults such as time outs, table extensions, device addresses, etc., can be directly specified via the GEN record. This process can simplify answer file preparation. See the RTE-L SYSTEM DESIGN manual for additional information on the use of the GEN statement. ``` From Driver: DD.30 * Define Device Table Defaults for Discs GEN 9,EDD.30,TX:25,DX:8 * 7902 Defaults (2 LUs) GEN 11,M7902:0,TD:500,DT:30B GEN 13,DP:2:0:0:0:3:134:DP:7:30:2 * GEN 11,M7902:1,TD:500,DT:30B GEN 13,DP:2:1:0:0:3:134,DP:7:30:2 * * 7906 Defaults (4 LUs) GEN 11,M7906:0,DT:32B,TD:1100 GEN 13,DP:2:0:0:0:5:406,DP:7:48:1 ``` Figure 4-30. GEN Examples ## 4-10. ASSEMBLY LISTING CONTROL Assembly listing control pseudo instructions allow the user to control the assembly listing Output during pass 2 of the assembly process. List output is suppressed from the assembly listing, beginning with the UNL pseudo instruction and continuing for all instructions and comments until either an LST or END pseudo instruction is encountered. Diagnostic messages for errors encountered by the Assembler will be printed, however. The source statement sequence numbers (printed in columns 1-4 of the source program listing) are incremented for the instructions skipped. The LST pseudo instruction causes the source program listing, terminated by a UNL, to be resumed. A UNL following a UNL, an LST following an LST, and an LST not preceded by a UNL are not considered errors by the Assembler. The SUP pseudo instruction suppresses the output of additional code lines from the source program listing. Certain machine and pseudo instructions generate more than one line of coding. These additional code lines are suppressed by an SUP instruction until a UNS or the END pseudo instruction is encountered. SUP will suppress additional code lines in the following machine and pseudo instructions: | ADX | DJS | LAY | MLB | SBY | |-----|----------------------|----------------|-----|-----| | ADY | $\operatorname{DLD}$ | LBX | MPY | SJP | | ASC | DST | LBY | MSA | SJS | | BYT | FAD | LDX | MSB | STX | | CBS | FDV | LDY | MVW | STY | | CBT | $\mathbf{FMP}$ | $\mathbf{MBT}$ | OCT | TBS | | CMW | FSB | MCA | SAX | UJP | | DEC | JLY | MCB | SAY | UJS | | DIV | $\mathbf{JPY}$ | MDB | SBS | XMM | | DJP | LAX | MLA | SBX | XMS | The SUP pseudo instruction may be used to suppress the listing of literals at the end of the source program listing and also to suppress the printing of offset values for memory reference instructions which refer to external symbols with offsets. The UNS pseudo instruction causes the printing of additional coding lines, terminated by an SUP, to be resumed. An SUP preceded by another SUP, UNS preceded by UNS, or UNS not preceded by an SUP are not considered errors by the Assembler. The SKP pseudo instruction causes the source program listing to be skipped to the top of the next page. The SKP instruction is not listed, but the source statement sequence number is incremented for the SKP. The SPC pseudo instruction causes the source program listing to be skipped a specified number of lines. The list output is skipped n lines, or to the bottom of the page, whichever occurs first. The n may be any absolute expression. The SPC instruction is not listed but the source statement sequence number is incremented for the SPC. The HED pseudo instruction allows the programmer to specify a heading to be printed at the top of each page of the source program listing. This header is printed in addition to the standard header printed by the Assembler. The heading, a string of up to 56 ASCII characters, is printed at the top of each of the source program listings following the occurrence of the HED pseudo instruction. If HED is the first statement at the beginning of a program, the heading will be used on the first page of the source program listing. A HED instruction placed elsewhere in the program causes a skip to the top of the next page. The heading specified in the HED pseudo instruction will be used on every page until it is changed by a succeeding HED instruction. The source statement containing the HED will not be listed, but the source statement sequence number will be incremented. # 4-11. ARITHMETIC SUBROUTINE CALLS If an X appears in the control statement for the source program, the Assembler generates calls to arithmetic subroutines external to the source program for the following instructions: MPY, DIV, DLD, and DST. The instruction formats and functions are as described in paragraph 3-17 of Section III in this manual. If an F *does not* appear in the control statement for the source program, the Assembler generates calls to arithmetic subroutines external to the source program for the following instructions: FMP, FDV, FAD, and FSB. The instruction formats and functions are as described in paragraph 3-18 of Section III in this manual. Each use of a statement from this group except FIX and FLT generates two words of instructions. Symbolically, they could be represented as follows: JSB <.arithmetic pseudo operation> DEF m [,I] An EXT < arithmetic pseudo operation> is implied preceding the JSB operation. In the above operations, the overflow bit is set when one of the following conditions occurs: - Integer overflow - Floating point overflow or underflow - Division by zero. Execution of any of the subroutines alter the contents of the E-Register. ## 4-12. DEFINE USER INSTRUCTION | <br>L | | | |-------|-------------------|----------| | MIC | opcode,fcode,pnum | comments | This pseudo instruction provides the user the capability of defining his own instructions. opcode is a three-character alphabetic mnemonic, fcode is an instruction code, and pnum declares how many (0-7) parameter addresses are to be associated with the newly-defined instruction. Both fcode and pnum may be expressions which generate an absolute result. A user-defined instruction must not appear in the source program prior to the MIC pseudo instruction which defines it. When the user-defined mnemonic is used later in the source program, the specified number of parameter addresses (pnum) are supplied in the Operand field of the user-defined instruction separated from one another by spaces. The parameter addresses may be any addressable values, relocatable and/or indirect. The parameters may not be literals. Note: All three operands (opcode, fcode, and pnum) must be supplied in the MIC pseudo instruction in order for the pseudo instruction in order for the specified instruction to be defined. If *pnum* is zero, it must be expressly de- clared as such (not omitted). # 4-13. "JUMP TO MICROPROGRAM" (HP 1000 M, E, F-SERIES ONLY) The MIC pseudo instruction is primarily intended to facilitate the passing of control from an assembly language program to a user's microprogram residing in Read-Only-Memory (ROM) or Writable Control Store (WCS). Ordinarily, to do this the user must include an OCT 101xxx or OCT 105xxx statement (where xxx is 140 through 737) at the point in the source program where the jump is to occur. If parameters are to be passed, they are usually defined as constants (via OCT or DEF statements) immediately following the OCT 105xxx statement. With the MIC pseudo instruction, the user can define a source language instruction which passes control and a series of parameter addresses to a microprogram. If it is desired to pass additional parameters to a microprogram beyond those pointed to by the user-defined instruction, they must be defined as constants (via OCT or DEF statements) immediately following each use of the user-defined instruction. 4-14. **EXAMPLE.** Assume that the first two parameters to be passed from the assembly language program to the user's microprogram reside in the memory locations PARM1 and PARM2 and that the third parameter resides in the memory location pointed to by ADR. Also assume that the octal code for transferring control to the particular microprogram is $105240_{\rm g}$ . The following statement defines a source language instruction which passes control and three parameter addresses to the microprogram: MIC ABC,105240B,3 Whenever it is desired to pass control from the assembly language program to the microprogram, the following user-defined instruction may be used in the source program: ABC PARM1 PARM2 ADR.I # 4-15. COMBINING MULTIPLE MNEMONICS Another use of the MIC pseudo instruction is to assign a single mnemonic to a multiple instruction (shift-rotate or alter-skip) statement. **4-16. EXAMPLE.** Instead of using the source statement: ALR, CLE, SLA, RAL the user may define a single mnemonic as follows: MIC XYZ,01472B,0 where 01472B is the octal instruction code for the fourmnemonic statement shown above. Whenever XYZ is subsequently used as an instruction mnemonic in the source program, it is the equivalent of using the source statement: ALR, CLE, SLA, RAL #### 4-17. DEFINING CONSTANTS The MIC pseudo instruction may also be used for defining constants (opcode = mnemonic, fcode = constant, and pnum = 0). Whenever the defined mnemonic is used as an instruction mnemonic in the source program the Assembler automatically replaces it with the specified constant. **4-18. EXAMPLE.** The following statement defines the constant $10_{10}$ and assigns it the mnemonic TEN: MIC TEN,10,0 Whenever TEN appears as an instruction mnemonic later in the source program, the value $10_{10}$ is automatically inserted in that location by the Assembler. ## 4-19. ALTERNATE MICROCODE REFERENCE INSTRUCTION (21MX Series and 2100 Only) An alternate but somewhat restricted way to access microprogrammed functions from the Assembler language is by employing the RAM (Random Access Memory) pseudoinstruction. The RAM pseudo-instruction will generate an executable machine instruction which when executed will cause a jump to microcode. The high order bits of the instruction will be 105 octal and the low order bits will be the octal value of m. m must evaluate to an absolute expression in the range 0 to 377 octal. **4-20. EXAMPLE.** The following lines of assembly code: RAM B16 B16 EQU 16B will generate this octal object code: 105016 # HP CHARACTER SET FOR COMPUTER SYSTEMS **APPENDIX** A EXAMPLE: The representation for the character "K" (column 4, row 11) is. <sup>\*</sup> Depressing the Control key while typing an upper case letter produces the corresponding control code on most terminals. For example, Control-H is a backspace. #### **HEWLETT-PACKARD CHARACTER SET FOR COMPUTER SYSTEMS** This table shows HP's implementation of ANS X3.4-1968 (USASCII) and ANS X3.32-1973. Some devices may substitute alternate characters from those shown in this chart (for example, Line Drawing Set or Scandanavian font). Consult the manual for your device. The left and right byte columns show the octal patterns in a 16 bit word when the character occupies bits 8 to 14 (left byte) or 0 to 6 (right byte) and the rest of the bits are zero. To find the pattern of two characters in the same word, add the two values. For example, "AB" produces the octal pattern 040502. (The parity bits are zero in this chart.) The octal values 0 through 37 and 177 are control codes. The octal values 40 through 176 are character codes. | Decimal | Octal Values | | | 1 | | | |---------|--------------|------------|-------------------------------|----------------|-----------------------------|--| | Value | Left Byte | Right Byte | Mnemonic Graphic <sup>1</sup> | | Meaning | | | 0 | 000000 | 000000 | NUL | 75 | Null | | | 1 | 000400 | 000001 | son | ¶. | Start of Heading | | | 2 | 001000 | 000002 | STX | ₹. | Start of Text | | | 3 | 001400 | 000003 | EXT | 5x | End of Text | | | 4 | 002000 | 000004 | EOT | 두 | End of Transmission | | | 5 | 002400 | 000005 | ENQ | € | Enquiry | | | 6 | 003000 | 000006 | ACK | ٩k | Acknowledge | | | 7 | 003400 | 000007 | BEL | | Bell, Attention Signal | | | 8 | 004000 | 000010 | BS | <b>6</b> | Backspace | | | 9 | 004400 | 000011 | нт | - 4- | Horizontal Tabulation | | | 10 | 005000 | 000012 | LF | L <sub>F</sub> | Line Feed | | | 11 | 005400 | 000013 | VT | 4 | Vertical Tabulation | | | 12 | 006000 | 000014 | FF | F | Form Feed | | | 13 | 006400 | 000015 | CR | G <sub>R</sub> | Carriage Return | | | 14 | 007000 | 000016 | so | ₹ | Shift Out Alternate | | | 15 | 007400 | 000017 | SI | 5, | Shift In Set | | | 16 | 010000 | 000020 | DLE | ٩ | Data Link Escape | | | 17 | 010400 | 000021 | DC1 | D <sub>1</sub> | Device Control 1 (X-ON) | | | 18 | 011000 | 000022 | DC2 | 02 | Device Control 2 (TAPE) | | | 19 | 011400 | 000023 | DC3 | ο, | Device Control 3 (X-OFF) | | | 20 | 012000 | 000024 | DC4 | 04 | Device Control 4 (TAPE) | | | 21 | 012400 | 000025 | NAK | nk . | Negative Acknowledge | | | 22 | 013000 | 000026 | SYN | S <sub>r</sub> | Synchronous Idle | | | 23 | 013400 | 000027 | ETB | 튭 | End of Transmission Block | | | 24 | 014000 | 000030 | CAN | G <sub>N</sub> | Cancel | | | 25 | 014400 | 000031 | EM | F <sub>4</sub> | End of Medium | | | 26 | 015000 | 000032 | SUB | ₹6 | Substitute | | | 27 | 015400 | 000033 | ESC | Ę | Escape <sup>2</sup> | | | 28 | 016000 | 000034 | FS | Fs | File Separator | | | 29 | 016400 | 000035 | GS | G <sub>5</sub> | Group Separator | | | 30 | 017000 | 000036 | RS | R <sub>S</sub> | Record Separator | | | 31 | 017400 | 000037 | US | 4 | Unit Separator | | | 127 | 077400 | 000177 | DEL | <b>\$</b> | Delete, Rubout <sup>3</sup> | | | Decimal | Octal Values | | | | | |----------------------------------------------------------|--------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------|-----------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--| | Value | Left Byte | Right Byte | Character | Meaning | | | 32<br>33 | 020000<br>020400 | 000040<br>000041 | ! | Space, Blank Exclamation Point | | | 34<br>35<br>36<br>37<br>38<br>39<br>40<br>41<br>42<br>43 | 021000<br>021400<br>022000<br>022400<br>023000<br>023400<br>024000<br>024400<br>025000<br>025400 | 000042<br>000043<br>000044<br>000045<br>000046<br>000047<br>000050<br>000051<br>000052<br>000053 | ** ** ** () ** + | Quotation Mark Number Sign, Pound Sign Dollar Sign Percent Ampersand, And Sign Apostrophe, Acute Accent Left (opening) Parenthesis Right (closing) Parenthesis Asterisk, Star Plus | | | 44<br>45<br>46<br>47<br>48 | 026000<br>026400<br>027000<br>027400<br>030000 | 000054<br>000055<br>000056<br>000057 | ,<br>-<br>/ | Comma, Cedilla<br>Hyphen, Minus, Dash<br>Period, Decimal Point<br>Slash, Slant | | | 48<br>49<br>50<br>51<br>52<br>53 | 030400<br>031400<br>031400<br>032000<br>032400 | 000060<br>000061<br>000062<br>000063<br>000064 | 1<br>2<br>3<br>4<br>5 | Digits, Numbers | | | 54<br>55<br>56<br>57 | 033000<br>033400<br>034000<br>034400 | 000066<br>000067<br>000070<br>000071 | 6<br>7<br>8<br>9 | | | | 58<br>59<br>60<br>61<br>62<br>63 | 035000<br>035400<br>036000<br>036400<br>037000<br>037400 | 000072<br>000073<br>000074<br>000075<br>000076 | :<br>;<br>=<br>><br>? | Colon Semicolon Less Than Equals Greater Than Question Mark | | 9206-1B | | Octal Values | | · | | |------------------|--------------|------------|-----------|------------------------------| | Decimal<br>Value | Left Byte | Right Byte | Character | Meaning | | 64 | 040000 | 000100 | @ | Commercial At | | 65 | 040400 | 000101 | Α | ` | | 66 | 041000 | 000102 | В | | | 67 | 041400 | 000103 | С | | | 68 | 042000 | 000104 | D | | | 69 | 042400 | 000105 | E | | | 70 | 043000 | 000106 | F | | | 71 | 043400 | 000107 | G | | | 72 | 044000 | 000110 | н | | | 73 | 044400 | 000111 | ı | | | 74 | 045000 | 000112 | J | | | 75 | 045400 | 000113 | к | | | 76 | 046000 | 000114 | L | | | 77 | 046400 | 000115 | м | User Oser Alababat | | 78 | 047000 | 000116 | N | Upper Case Alphabet, | | 79 | 047400 | 000117 | 0 | Capital Letters | | 80 | 050000 | 000120 | Р | | | 81 | 050400 | 000121 | Q | | | 82 | 051000 | 000122 | R | | | 83 | 051400 | 000123 | s | | | 84 | 052000 | 000124 | Т | | | 85 | 052400 | 000125 | U | | | 86 | 053000 | 000126 | V | | | 87 | 053400 | 000127 | w | | | 88 | 054000 | 000130 | × | | | 89 | 054400 | 000131 | Y | | | 90 | 055000 | 000132 | Z | / | | 91 | 055400 | 000133 | [ | Left (opening) Bracket | | 92 | 056000 | 000134 | \ | Backslash, Reverse Slant | | 93 | 056400 | 000135 | ] | Right (closing) Bracket | | 94 | 057000 | 000136 | ^ ↑ | Caret, Circumflex; Up Arrow4 | | 95 | 057400 | 000137 | ← | Underline; Back Arrow4 | | Decimal | Octal Values | | | | | |---------|--------------|------------|-----------|------------------------------------|--| | Value | Left Byte | Right Byte | Character | Meaning | | | 96 | 060000 | 000140 | | Grave Accent <sup>5</sup> | | | 97 | 060400 | 000141 | a | | | | 98 | 061000 | 000142 | ь | | | | 99 | 061400 | 000143 | С | ' | | | 100 | 062000 | 000144 | d | | | | 101 | 062400 | 000145 | е | | | | 102 | 063000 | 000146 | f | | | | 103 | 063400 | 000147 | g | | | | 104 | 064000 | 000150 | h | | | | 105 | 064400 | 000151 | i | | | | 106 | 065000 | 000152 | j | | | | 107 | 065400 | 000153 | k | | | | 108 | 066000 | 000154 | ı | | | | 109 | 066400 | 000155 | m | | | | 110 | 067000 | 000156 | n | Lower Case Letters <sup>5</sup> | | | 111 | 067400 | 000157 | 0 | | | | 112 | 070000 | 000160 | р | | | | 113 | 070400 | 000161 | q | | | | 114 | 071000 | 000162 | r | | | | 115 | 071400 | 000163 | s | | | | 116 | 072000 | 000164 | t | | | | 117 | 072400 | 000165 | u | | | | 118 | 073000 | 000166 | v | | | | 119 | 073400 | 000167 | w | | | | 120 | 074000 | 000170 | x | | | | 121 | 074400 | 000171 | у | | | | 122 | 075000 | 000172 | z | <i>]</i> | | | 123 | 075400 | 000173 | { | Left (opening) Brace⁵ | | | 124 | 076000 | 000174 | | Vertical Line <sup>5</sup> | | | 125 | 076400 | 000175 | } | Right (closing) Brace <sup>5</sup> | | | 126 | 077000 | 000176 | ~ | Tilde, Overline <sup>5</sup> | | | | | | | | | Notes: ¹This is the standard display representation. The software and hardware in your system determine if the control code is displayed, executed, or ignored. Some devices display all control codes as "||", "@", or space. <sup>2</sup>Escape is the first character of a special control sequence. For example, ESC followed by "J" clears the display on a 2640 terminal. $^3\mbox{Delete}$ may be displayed as "\_\_", "@", or space. <sup>4</sup>Normally, the caret and underline are displayed. Some devices substitute the up arrow and back arrow. <sup>5</sup>Some devices upshift lower case letters and symbols ( \ through ~) to the corresponding upper case character (@ through \(\lambda\)). For example, the left brace would be converted to a left bracket. **HP 7970B BCD-ASCII CONVERSION** | SYMBOL | BCD<br>(OCTAL CODE) | ASCII<br>EQUIVALENT<br>(OCTAL CODE) | SYMBOL | BCD<br>(OCTAL CODE) | ASCII<br>EQUIVALENT<br>(OCTAL CODE) | |---------|---------------------|-------------------------------------|----------|---------------------|-------------------------------------| | (space) | 20 | 040 | @ | 14 | 100 | | ! | 52 | 041 | А | 61 | 101 | | " | 37 | 042 | В | 62 | 102 | | # | 13 | 043 | С | 63 | 103 | | \$ | 53 | 044 | D | 64 | 104 | | % | 57 | 045 | Е | 65 | 105 | | & | † | 046 | F | 66 | 106 | | , | 35 | 047 | G | 67 | 107 | | ( | 34 | 050 | н | 70 | 110 | | ) | 74 | 051 | ı | 71 | 111 | | * | 54 | 052 | J | 41 | 112 | | + | 60 | 053 | К | 42 | 113 | | , | 33 | 054 | L | 43 | 114 | | - | 40 | 055 | M | 44 | 115 | | • | 73 | 056 | N | 45 | 116 | | / | 21 | 057 | 0 | 46 | 117 | | 0 | 12 | 060 | P | 47 | 120 | | 1 | 01 | 061 | Q | 50 | 121 | | 2 | 02 | 062 | R | 51 | 122 | | 3 | 03 | 063 | S | 22 | 123 | | 4 | 04 | 064 | Т | 23 | 124 | | 5 | 05 | 065 | υ | 24 | 125 | | 6 | 06 | 066 | V | 25 | 126 | | 7 | 07 | 067 | w | 26 | 127 | | 8 | 10 | 070 | × | 27 | 130 | | 9 | 11 | 071 | Y | 30 | 131 | | : | 15 | 072 | z | 31 | 132 | | ; | 56 | 073 | [ | 75 | 133 | | < | 76 | 074 | `\ | 36 | 134 | | = | 17 | 075 | ] | 55 | 135 | | > | 16 | 076 | <b>1</b> | 77 | 136 | | ? | 72 | 077 | <b>←</b> | 32 | 137 | †The ASCII code 046 is converted to the BCD code for a space (20) when writing data onto a 7-track tape. # B # **SUMMARY OF INSTRUCTIONS** Meaning Symbols | label | Symbolic label, 1-5 alphanumeric characters and periods | |--------------------|---------------------------------------------------------| | m | Memory location represented by an expression | | I | Indirect addressing indicator | | $\mathbf{c}$ | Clear flag indicator | | (m,m+1) | Two-word floating point value in m and m+1 | | comments | Optional comments | | [] | Optional portion of field | | { } | One of set may be selected | | P | Program Counter | | ( ) | Contents of location | | $\wedge$ | Logical product | | <b>∀</b> | Exclusive "or" | | V | Inclusive "or" | | A | A-register | | В | B-register | | ${f E}$ | E-register | | $A_n$ | Bit n of A-register | | $B_n$ | Bit n of B-register | | b | Bit positions in B- and A-register | | $(\overline{A/B})$ | Complement of contents of register A or B | | (AB) | Two-word floating point value in register A and B | | sc | Channel select code represented by an expression | | d | Decimal constant | | o | Octal constant | | r | Repeat count | | n | Integer constant | | lit | Literal value | | msb | Most significant bits | | lsb | Least significant bits | | | | NOTE: Instruction groups shaded in gray are implemented in software on L-SERIES systems. #### **B-1. MACHINE INSTRUCTIONS** #### **B-2. MEMORY REFERENCE** #### B-3. Jump and Increment-Skip (m) + 1 $$\rightarrow$$ m: then if (m) = 0, execute P + 2 otherwise execute P + 1 Jump to m; $$m \rightarrow P$$ Jump subroutine to m: $$P + 1 \rightarrow m$$ ; $m + 1 \rightarrow P$ #### B-4. Add, Load and Store $$ADA \quad \left\{ m \ [,I] \atop lit \right\}$$ $$(m) + (A) \rightarrow A$$ $$ADB = \left\{ \begin{array}{ll} m \ [,I] \\ lit \end{array} \right\}$$ $$(m) + (B) \rightarrow B$$ $$LDA \quad \left\{ m \ [,I] \atop lit \right\}$$ $$(m) \rightarrow A$$ $$LDB \quad \left\{ {{m\atop lit}}^{m\;[,I]} \right\}$$ $$(m) \rightarrow B$$ $$(A) \rightarrow m$$ $$(B) \rightarrow m$$ #### B-5. Logical $$AND \quad \left\{ \begin{matrix} m & [,I] \\ lit \end{matrix} \right\}$$ $$(m) \wedge (A) \rightarrow A$$ $$XOR \quad \left\{ \begin{smallmatrix} m & [,I] \\ lit \end{smallmatrix} \right\}$$ $$(m) \forall (A) \rightarrow A$$ $$IOR \qquad \left\{ \begin{smallmatrix} m & \text{[,I]} \\ \text{lit} \end{smallmatrix} \right\}$$ $$(m) \lor (A) \rightarrow A$$ $$CPA = \left\{ \begin{array}{ll} m \; \text{[,I]} \\ lit \end{array} \right\}$$ If (m) $\neq$ (A), execute P + 2, otherwise execute P + 1 CPB $$\left\{ \begin{array}{ll} \mathbf{m} \ [,\mathbf{I}] \\ \mathbf{lit} \end{array} \right.$$ If (m) $\neq$ (B), execute P + 2, otherwise execute P + 1 #### **B-6.** Word Processing $$MVW = \left\{ \begin{array}{l} m & [,I] \\ lit \end{array} \right\}$$ Move (m) words from array (A)→array (B) $$CMW \left\{ \begin{array}{l} m \ [,I] \\ lit \end{array} \right\}$$ Compare (m) words of array (A) against (m) words of array (B); if the two arrays are equal, execute P+3, if array (A) is less than array (B), execute P+4, if array (A) is greater than array (B), execute P+5 #### **B-7.** Byte Processing LBT B contains a 16-bit byte address; $((B)) \rightarrow A_{0-7}$ ; o's to $A_{8-15}$ SBT B contains a 16-bit byte address; $(A_{0-7}) \rightarrow (B)$ MBT $\left\{\begin{array}{l} m \ [,I] \\ lit \end{array}\right\}$ A and B contain 16-bit byte addresses; move (m) bytes from array (A) $\rightarrow$ array (B) CBT $\left\{ \begin{array}{l} m & [,I] \\ lit \end{array} \right\}$ A and B contain 16-bit byte addresses; compare (m) bytes of array (A) against (m) bytes of array (B); if the two arrays are equal, execute P + 3; if array (A) is less than array (B), execute P + 4; if array (A) is greater than array (B), execute P + 5 $A_{0-7}$ contain the test byte, $A_{8-15}$ contain the termination byte, and B contains a 16-bit byte address; scan array (B); if test byte found, execute P+1, B contains address of test byte; if termination byte found, execute P+2, B contains address of termination byte; if neither is found, execute P+2, B contains zero #### B-8. Bit Processing SFB TBS $\left\{\begin{array}{l} m \\ lit \end{array}\right\}$ n [,I] Compare all "set" bits in (m) against corresponding bits in (n); if all bits tested are set, execute P + 3; if any of the bits tested are clear, execute P + 4 SBS $\left\{\begin{array}{l} m \\ lit \end{array}\right\}$ n [,I] Set all bits in (n) which correspond to "set" bits in (m) CBS $\left\{\begin{array}{l} m & [I] \\ lit \end{array}\right\}$ n [I] Clear all bits in (n) which correspond to "set" bits in (m) #### B-9. REGISTER REFERENCE #### B-10. Shift-Rotate **CLE** 0 →**E** ALS Shift (A) left one bit, $0 \rightarrow A_0$ , $A_{15}$ unaltered BLS Shift (B) left one bit, $0 \rightarrow B_0$ , $B_{15}$ unaltered ARS Shift (A) right one bit, $(A_{15}) \rightarrow A_{14}$ BRS Shift (B) right one bit, $(B_{15}) \rightarrow B_{14}$ RAL Rotate (A) left one bit RBL Rotate (B) left one bit RAR Rotate (A) right one bit RBR Rotate (B) right one bit ALR Shift (A) left one bit, $0 \rightarrow A_{15}$ BLR Shift (B) left one bit, $0 \rightarrow B_{15}$ ERA Rotate E and A right one bit ERB Rotate E and B right one bit ELA Rotate E and A left one bit ELB Rotate E and B left one bit ALF Rotate A left four bits BLF Rotate B left four bits SLA If $(A_0) = 0$ , execute P + 2, otherwise execute P + 1 SLB If $(B_0) = 0$ , execute P + 2, otherwise execute P + 1 Shift-Rotate instructions can be combined as follows: #### **B-11.** No-Operation NOP Execute P + 1 #### B-12. Alter-Skip - CLA $0's \rightarrow A$ - CLB 0's →B - CMA $\overline{(A)} \rightarrow A$ - CMB $(\overline{B}) \rightarrow B$ - CCA 1's →A - CCB 1's →B - CLE $0 \rightarrow E$ - CME $(\overline{E}) \rightarrow E$ - CCE $1 \rightarrow E$ - SEZ If (E) = 0, execute P + 2, otherwise execute P + 1 - SSA If $(A_{15}) = 0$ , execute P + 2, otherwise execute P + 1 - SSB If $(B_{15}) = 0$ , execute P + 2, otherwise execute P + 1 - INA $(A) + 1 \rightarrow A$ - INB (B) $+ 1 \rightarrow B$ - SZA If (A) = 0, execute P + 2, otherwise execute P + 1 - SZB If (B) = 0, execute P + 2, otherwise execute P + 1 - SLA If $(A_0) = 0$ , execute P + 2, otherwise execute P + 1 - SLB If $(B_0) = 0$ , execute P + 2, otherwise execute P + 1 - RSS Reverse sense of skip instructions. If no skip instructions precede, execute P + 2 Alter-Skip instructions can be combined as follows: ``` \begin{bmatrix} \begin{bmatrix} \text{CLE} \\ \text{CME} \\ \text{CCE} \end{bmatrix} \end{bmatrix} [,SEZ] [,SSA] [,SLA] [,INA] [,SZA] [,RRS] \begin{bmatrix} \left\{ \begin{smallmatrix} \text{CLB} \\ \text{CMB} \\ \text{CCB} \end{smallmatrix} \right\} \end{bmatrix} \left\{egin{array}{c} ext{CLE} \\ ext{CME} \\ ext{CCE} \end{array} ight\} [,SEZ] [,SSB] [,SLB] [,INB] [,SZB] [,RSS] B-13. Index Register CAX (A) \rightarrow X CBX (B) \rightarrow X CAY (A) \rightarrow Y CBY (B) \rightarrow Y CXA (X) \rightarrow A CXB (X) \rightarrow B CYA (Y) \rightarrow A CYB (Y) \rightarrow B XAX (A) \rightarrow X and (X) \rightarrow A XBX (B) \rightarrow X and (X) \rightarrow B XAY (A) \rightarrow Y and (Y) \rightarrow A XBY (B) \rightarrow Y and (Y) \rightarrow B ISX (X) + 1 \rightarrow X, then test new (X); if (X) = 0, execute P + 2, otherwise execute P + 1 ISY (Y) + 1 \rightarrow Y, then test new (Y); if (Y) = 0, execute P + 2, otherwise execute P + 1 (X) \cdot 1 \rightarrow X, then test new (X); if (X) = 0, execute P \cdot + 2, otherwise execute P + 1 DSX DSY (Y) \cdot 1 \rightarrow Y, then test new (Y); if (Y) = 0, execute P + 2, otherwise execute P + 1 m [,I] LDX (m) \rightarrow X lit m [,I] LDY (m) \rightarrow Y lit STX m [,I] (X) \rightarrow m STY m [,I] (Y) \rightarrow m LAX m [,I] (m + (X)) \rightarrow A LBX m [,I] (m + (X)) \rightarrow B LAY m [,I] (m + (Y)) \rightarrow A LBY m [,I] (m + (Y)) \rightarrow B SAX m [,I] (A)\rightarrow m + (X) SBX m [,I] (B)\rightarrow m + (X) SAY m [,I] (A)\rightarrow m + (Y) SBY m [,I] (B)\rightarrow m + (Y) m[,I] ADX (m) + (X) \rightarrow X lit m[,I] (m) + (Y) \rightarrow Y ADY lit JLY Jump to m; P + 2 \rightarrow Y m[,I] JPY Jump to m + (Y) m ``` #### B-14. INPUT/OUTPUT, OVERFLOW, AND HALT #### B-15. Input/Output STC sc [,C] Set control bitsc, enable transfer of one element of data between devicesc and buffersc CLC sc [,C] Clear control bit<sub>sc</sub>. If sc = 0 clear all control bits LIA sc [,C] (buffer<sub>sc</sub>) $\rightarrow$ A LIB sc [,C] (buffer<sub>sc</sub>) $V(A) \rightarrow A$ Merge (inclusive or) the buffer into A. MIA sc [,C] (buffer<sub>sc</sub>) $V(B) \rightarrow B$ Merge (inclusive or) the buffer into B. MIB sc [,C] (buffer<sub>sc</sub>) $(B) \rightarrow B$ OTA sc [,C] $(A) \rightarrow buffer_{sc}$ OTB sc [,C] (B) $\rightarrow$ buffer<sub>sc</sub> STF sc Set flag bit<sub>sc</sub>. If sc = 0, enable interrupt system. sc = 1 sets overflow bit. CLF sc Clear flag bit<sub>sc</sub>. If sc = 0, disable interrupt system. If sc = 1, clear overflow bit. SFC sc If $(flag \ bit_{SC}) = 0$ , execute P + 2, otherwise execute P + 1. If sc = 1, test overflow bit. SFS sc If $(flag \ bit_{SC}) = 1$ , execute P + 2, otherwise execute P + 1. If sc = 1, test overflow bit. #### B-16. Overflow CLO $0 \rightarrow \text{overflow bit}$ STO 1→overflow bit SOC [C] If (overflow bit) = 0, execute P + 2, otherwise execute P + 1 SOS [C] If (overflow bit) = 0, execute P + 2, otherwise execute P + 1 #### B-17. Halt HLT [sc [,C]] Halt computer #### **B-18. EXTENDED ARITHMETIC UNIT** $MPY \qquad \left\{ {{m\atop lit}}^{[I,I]} \right\} \quad (A) \ x \ (m) \! \rightarrow \! (B_{\pm msb} \ \ and \ A_{lsb})$ $\mathrm{DIV} \qquad \left\{ \begin{matrix} m & [,I] \\ \mathrm{lit} \end{matrix} \right\} \quad (B_{\pm msb} \quad \text{and} \ A_{lsb})/(m) \rightarrow A, \ remainder \rightarrow B$ DLD ${m [I] \atop lit}$ (m) and (m + 1) $\rightarrow$ A and B DST ${m [I,I] \atop lit}$ (A) and (B) $\rightarrow$ m and m + 1 ASR b Arithmetically shift (BA) right b bits, B<sub>15</sub> extended ASL b Arithmetically shift (BA) left b bits, B<sub>15</sub> unaltered, 0's to A<sub>lsb</sub> RRR b Rotate (BA) right b bits RRLRotate (BA) left b bits b LSR Logically shift (BA) right b bits, 0's to B<sub>msb</sub> b Logically shift (BA) left b bits, o's to Alsb LSL b **SWP** Swap the contents of the A and B registers #### **B-19. FLOATING POINT** words moved. #### B-20. **MEMORY EXPANSION** | DJP | m [,I] | Disable MEM and jump to m; $m \rightarrow P$ | |-----|------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------| | DJS | m [,I] | Disable MEM and jump subroutine to m; $P+1 \rightarrow m$ ; $m+1 \rightarrow P$ | | JRS | $m_{t}\left[ ,I\right] m_{2}\left[ ,I\right]$ | Jump and restore status | | LFA | | $A \rightarrow fence$ | | LFB | | $B \longrightarrow fence$ | | MBF | | Move bytes from alternate map. $X \leftarrow 0$ ; $A \leftarrow A + no.$ bytes moved; $B \leftarrow B + no.$ bytes moved. | | MBI | | Move bytes into alternate map. $X \leftarrow 0$ ; $A \leftarrow A + no.$ bytes moved; $B \leftarrow B + no.$ bytes moved. | | MBW | | Move bytes within alternate map. $X \leftarrow 0$ ; $A \leftarrow A + no.$ bytes moved; $B \leftarrow B + no.$ bytes moved. | | MWF | | Move words from alternate map. $X \leftarrow 0$ ; $A \leftarrow A + no.$ words moved; $B \leftarrow B + no.$ words moved. | | MWI | | Move words into alternate map. $X \leftarrow 0$ ; $A \leftarrow A + no.$ words moved; $B \leftarrow B + no.$ words moved. | | MWW | | Move words within alternate map. $X \leftarrow 0$ ; $A \leftarrow A + no.$ words moved; $B \leftarrow B + no.$ | ``` PAA If A(15) = 0, Port A map \leftarrow memory; if A(15) = 1, Port A map \rightarrow memory. PAB If B(15) = 0, Port A map \leftarrow memory; if B(15) = 1, Port A map \rightarrow memory. PBA If A(15) = 0, Port B map \leftarrow memory; if A(15) = 1, Port B map \rightarrow memory. PBB If B(15) = 0, Port B map \leftarrow memory; if B(15) = 1, Port B map \rightarrow memory. RSA A \leftarrow status register RSB B \leftarrow status register RVA A \leftarrow violation register RVB B ← violation register m [,I] SJP Enable System map and jump to m SJS m [,I] Enable System map and jump subroutine to m SSM m [,I] m \leftarrow status register SYA If A(15) = 0, System map \leftarrow memory; if A(15) = 1, System map \rightarrow memory. SYB If B(15) = 0, System map \leftarrow memory; if B(15) = 1, System map \rightarrow memory. UJP m [,I] Enable User map and jump to m UJS m[,I] Enable User map and jump subroutine to m USA If A(15) = 0, User map \leftarrow memory; if A(15) = 1, User map \rightarrow memory. USB If B(15) = 0, User map \leftarrow memory; if B(15) = 1, User map \rightarrow memory. XCA m [,I] Compare A with m; if A = m, execute P = 1; if A \neq m, execute P + 2. XCB m [,I] Compare B with m; if B = m, execute P + 1; if B \neq m, execute P + 2. XLA m[I] A \leftarrow m XLB m [,I] B \leftarrow m XMA If A(15) = 0 and A(0) = 0, Port A map \leftarrow System map. If A(15) = 0 and A(0) = 1, Port B map \leftarrow system map. If A(15) = 1 and A(0) = 0, Port A map \leftarrow User map. If A(15) = 0 1 and A(0) = 1, Port B map \leftarrow User map. XMB If B(15) = 0 and B(0) = 0, Port A map \leftarrow System map. If B(15) = 0 and B(0) = 1, Port B map \leftarrow System map. If B(15) = = 1 and B(0) = 0, Port A map \leftarrow User map. If B(15) = 1 and B(0) = 1, Port B map \leftarrow User map. XMM A = register no., B = memory address, X = no. of registers. If X > 0, Maps \leftarrow memory; if X < 0, Memory \leftarrow maps. XMS A = first register no., B = first page no., X = positive no. of registers. First register is loaded with the page number indicated in B, the second register is loaded with that value + 1, and so forth. XSA m [,I] A \rightarrow m XSB m [,I] B \rightarrow m ``` ## **B-21. PSEUDO INSTRUCTIONS** #### B-22. ASSEMBLER CONTROL | NAM | [name] | Specifies relocatable program and its name. | |------------------------------------------|--------|----------------------------------------------------------------------------------------------------------| | ORB | | Gives relocatable program origin for the base page of relocatable program. | | ORG | m | Gives absolute program origin or origin for a segment of relocatable or absolute program. | | ORR | | Reset main program location counter at value existing when first ORG or ORB of a string was encountered. | | END | [m] | Terminates source language program. Produces transfer to program starting location, m, if given. | | REP<br><statement></statement> | r | Repeat immediately following statement r times. | | IFN<br><statements><br/>XIF</statements> | | Include statements in program if control statement contains N. | | IFZ<br><statements><br/>XIF</statements> | | Include statements in program if control statement contains Z. | #### **B-23. OBJECT PROGRAM LINKAGE** | COM | $name_1[(size_1)][,name_2[(size_2)],,name_n[(size_n)]]$ | |-------|-----------------------------------------------------------------------------------------------------------| | | Reserves a block of common storage locations. $name_1$ identifies segments of block, each of length size. | | ENT | $name_1[,name_2,,name_n]$ | | | Defines entry points, name <sub>1</sub> , that may be referred to by other programs. | | EXT | $name_1[,name_2,\ldots,name_n]$ | | | Defines external locations, name, which are labels of other programs, referenced by this program. | | label | RPL[m] | | | Defines the code replacement for [JSB label] external references. | ## **B-24.** ADDRESS AND SYMBOL DEFINITION | label | DEF m [,I] | Generates a 15-bit address which may be referenced indirectly through the label. | |-------|------------|------------------------------------------------------------------------------------------------------------| | label | ABS m | Defines a 16-bit absolute value to be referenced by the label. | | label | EQU m | Equates the value, m, to the label. | | label | DBL m | Defines a 16-bit byte address (left half, bits 8-15, of word location $m$ ) to be referenced by the label. | label DBR m Defines a 16-bit byte address to be referenced by the label. The byte address is for the right half (bits 0-7) of word location m. #### **B-25. CONSTANT DEFINITION** ASC n, <2n characters> Generates a string of 2n ASCII characters. DEC $d_1$ [, $d_2$ ,..., $d_n$ ] Records a string of decimal constants of the form: Integer: ±n Floating point: $\pm n.n$ , $\pm n.$ , $\pm n.$ , $\pm n.$ DEX d<sub>1</sub> [,d<sub>2</sub>,...,d<sub>n</sub>] Records a string of extended precision decimals constants of the form Floating point: $\pm n$ , $\pm n$ .m, $\pm n$ ., $\pm .n$ , $\pm$ nE $\pm$ e, $\pm$ n.nE $\pm$ e, $\pm$ n.E $\pm$ e, $\pm$ .nE $\pm$ e DEY d<sub>1</sub> [,d<sub>2</sub>,...,d<sub>n</sub>] Records a string of four-word extended precision decimal constants in the same form as DEX. OCT o<sub>1</sub> [,o<sub>2</sub>,...,o<sub>n</sub>] Records a string of octal constants of the form: ±000000 BYT b [,b, ...,b<sub>n</sub>] Records a string of octal byte constants of the form: $\pm$ nnn (where nn is 0 through $377_{8}$ ). #### **B-26. STORAGE ALLOCATION** BSS m Reserves a storage area of length, m. EMA $m_1, m_2$ Extended Memory Area of size $m_1 m$ NSEG= $m_2$ . #### **B-27. RTE-L PSEUDO INSTRUCTIONS** LOD n,<2n characters> Generates a string of 2n ASCII characters representing a RTE-L loader command. GEN n,<2n characters> Generates a string of 2n ASCII characters representing a RTE-L generator command. #### **B-28. ASSEMBLY LISTING CONTROL** UNL Suppress assembly listing output. LST Resume assembly listing output. SKP Skip listing to top of next page. SPC n Skip n lines on listing. SUP Suppress listing of extended code lines (e.g., as produced by subroutine calls). UNS Resume listing of extended code lines. HED <heading> Print <heading> at top of each page, where <heading> is up to 56 ASCII characters. #### **B-29. DEFINE USER INSTRUCTION** MIC opcode, fcode, pnum Defines a source language instruction. opcode = three-character alphabetic mnemonic, fcode = instruction code, and pnum declares how many parameter addresses are to be associated with the newly-defined instruction. #### B-30. GENERATE AN EXECUTABLE MACHINE INSTRUCTION TO JUMP TO MICROCODE RAM m Generates an executable machine instruction whose high order bits will be 105(octal), and whose low order bits will be the octal value of m. m must evaluate to an absolute expression in the range 0 to 377 octal. ## **APPENDIX** # **ALPHABETIC LIST OF INSTRUCTIONS** C | Note: | In the following list, those instructions | CLF Clear I/O flag | |----------------|--------------------------------------------------------------------------------|--------------------------------------------------| | | suffixed with an asterisk are dynamic | CLO Clear overflow bit | | | mapping instructions and cannot be used unless the computer contains a Dynamic | CMA Complement A | | | Mapping System. Those instructions | CMB Complement B | | | shaded in gray are implemented in software on RTE-L systems. They are | CME Complement E | | | not available as RTE-L hardware | CMW Compare words | | | instructions. | COM Reserve block of common storage | | ABS | Define absolute value | CPA Compare to A, skip if unequal | | ADA | Add to A | CPB Compare to B, skip if unequal | | ADB | Add to B | CXA Copy X to A | | ADX | Add memory to X | CXB Copy X to B | | ADY | Add memory to Y | CYA Copy Y to A | | ALF | Rotate A left 4 | CYB Copy Y to B | | ALR | Shift A left 1, clear sign | DBL Define left byte (bits 8-15) address | | ALS | Shift A left 1 | DBR Define right byte (bits 0-7) address | | AND | "And" to A | DEC Define decimal constant | | ARS | Shift A right 1, sign carry | DEF Define address | | ASC | Generate ASCII characters | DEX Define extended precision constant | | ASL | Arithmetic long shift left | DEY Define four-word extended precision constant | | ASR | Arithmetic long shift right | DIV Divide | | | | DJP* Disable MEM and jump | | BLF | Rotate B left 4 | DJS* DISABLE MEM and jump to subroutine | | BLR | Shift B left 1, clear sign | DLD Double load | | BLS | Shift B left 1 | DST Double store | | BRS | Shift B right 1, carry sign | DSX Decrement X and skip if zero | | BSS | Reserve block of storage starting at symbol | DSY Decrement Y and skip if zero | | BYT | Defines octal byte constants | ELA Rotate E and A left 1 | | | | ELB Rotate E and B left 1 | | CAX | Copy A to X | EMA Extended Memory Area | | CAY | Copy A to Y | END Terminate program | | CBS | Clear bits | ENT Entry point | | CBT | Compare bytes | ERA Rotate E and A right 1 | | CBX | Copy B to X | ERB Rotate E and B right 1 | | CBY | Copy B to Y | EQU Equate symbol | | CCA | Clear and complement A (1's) | EXT External reference | | CCB | Clear and complement B (1's) | FAD Floating add | | CCE | Clear and complement $E$ (set $E = 1$ ) | FDV Floating divide | | CLA | Clear A | FIX Convert floating-point be fixed-point | | CLB | Clear B | FLT Convert fixed-point to floating-point | | $\mathbf{CLC}$ | Clear I/O control bit | FMP Floating multiply | | CLE | Clear E | FSB Floating subtract | | | | | | HED | Print heading at top of each page | MVW | Move words | |-------|--------------------------------------------------------------------|------|---------------------------------------| | HLT | Halt | MWF* | Move words from alternate map | | | | MWI* | Move words into alternate map | | IFN | When N appears in Control statement, assemble ensuing instructions | MWW* | Move words within alternate map | | IFZ | When Z appears in Control statement, assem- | NAM | Name relocatable program | | TNIA | ble ensuing instructions | NOP | No operation | | INA | Increment A by 1 | | | | INB | Increment B by 1 | OCT | Define octal constant | | IOR | Inclusive "or" to A | ORB | Establish origin in base page | | ISX | Increment X and skip if zero | ORG | Establish program origin | | ISY | Increment Y and skip if zero | ORR | Reset program location counter | | ISZ | Increment, then skip if zero | OTA | Output from A to I/O channel | | | ngan sa mangangkan kabupatèn ka | OTB | Output from B to I/O channel | | JLY | Jump and load Y | | | | JMP | Jump | PAA* | Load/store Port A map per A | | JPY | Jump indexed by Y | PAB* | Load/store Port A map per B | | JRS* | Jump and restore status | PBA* | Load/store Port B map per A | | JSB | Jump to subroutine | PBB* | Load/store Port B map per B | | LAX | Load A from memory indexed by X | RAL | Rotate A left 1 | | LAY | Load A from memory indexed by Y | RAM | Generate executable jump to microcode | | LBT . | Load byte | RAR | Rotate A right 1 | | LBX | Load B from memory indexed by X | RBL | Rotate B left 1 | | LBY | Load B from memory indexed by Y | RBR | Rotate B right 1 | | LDA | Load into A | REP | Repeat next statement | | LDB | Load into B | RPL | Replace instruction definition | | LDX | Load X from memory | RRL | Rotate A and B left | | LDY | Load Y from memory | RRR | Rotate A and B right | | LFA* | Load fence from A | RSA* | Read status register into A | | LFB* | Load fence from B | RSB* | Read status register into B | | LIA | Load into A from I/O channel | RSS | Reverse skip sense | | LIB | Load into B from I/O channel | RVA* | Read violation register into A | | LSL | Logical long shift left | RVB* | Read violation register into B | | LSR | Logical long shift right | 24.2 | Tiona Violation register Title B | | LST | Resume list output (follows a UNL) | SAX | Store A into memory indexed by X | | | | SAY | Store A into memory indexed by Y | | MBF* | Move bytes from alternate map | SBS | Set bits | | MBI* | Move bytes into alternate map | SBT | Store byte | | MBT | Move bytes | SBX | Store B into memory indexed by X | | MBW* | Move bytes within alternate map | SBY | Store B into memory indexed by Y | | MIA | Merge (or) into A from I/O channel | SEZ | Skip if $E = 0$ | | MIB | Merge (or) into B from I/O channel | SFB | Scan for byte | | MIC | Define jump to user microcode | SFC | Skip if I/O flag = 0 (clear) | | MPY | Multiply | SFS | Skip if I/O flag = 1 (set) | | SJP* | Enable System map and jump | TBS | Test bits | |------|-----------------------------------------------|---------|--------------------------------------------| | SJS* | Enable System map and jump to subroutine | | | | SKP | Skip to top of next page | $UJP^*$ | Enable User map and jump | | SLA | Skip if LSB of $A = 0$ | $UJS^*$ | Enable User map and jump to subroutine | | SLB | Skip if LSB of $B = 0$ | UNL | Suppress list output | | SOC | Skip if overflow bit $= 0$ (clear) | UNS | Resume list output | | SOS | Skip if overflow bit = $1$ (set) | USA* | Load/store User map per A | | SPC | Space n lines | USB* | Load/store User map per B | | SSA | Skip if sign $A = 0$ | XAX | Exchange A and X | | SSB | Skip if sign $B = 0$ | XAY | Exchange A and Y | | SSM* | Store status register in memory | XBX | Exchange B and X | | STA | Store A | XBY | Exchange B and Y | | STB | Store B | XCA* | Cross compare A | | STC | Set I/O control bit | XCB* | Cross compare B | | STF | Set I/O flag | XIF | Terminate IFN or IFZ group of instructions | | STO | Set overflow bit | XLA* | Cross load A | | STX | Store X into memory | XLB* | Cross load B | | STY | Store Y into memory | XMA* | Transfer maps internally per A | | SUP | Suppress list output of additional code lines | $XMB^*$ | Transfer maps internally per B | | SWP | Switch A and B | XMM* | Transfer map or memory | | SYA* | Load/store System map per A | XMS* | Transfer maps sequentially | | SYB* | Load/store System map per B | XOR | Exclusive "or" to A | | SZA | Skip if $A = 0$ | XSA* | Cross store A | | SZB | Skip if $B = 0$ | XSB* | Cross store B | | | | | | # **CONSOLIDATED CODING SHEETS** | APP | ENDIX | |-----|-------| | | D | Table D-1 presents the binary codes for the base set instructions while Table D-2 presents those for the extended instruction group. Table D-1. Base Set Instruction Codes in Binary | 15 | 14 | 13 | | 12 | 11 | 10 | 9 | 8 | | 7 | | 6 | 5 | 4 | 3 | 2 | 1 | | 0 | |------|-------|---------|--------|---------|-------------|---------|----------|-----|--------|-------------------------------------------|------|-----|-------------------|---------|-----------|-----------|-------------|--------------|-----| | D/I | AND | | 001 | | 0 | Z/C | | - | | | | Mem | ory Add | ress | | | | | | | D/I | XOR | | 010 | | 0 | Z/C | | | | | | | o, <b>,</b> , | . 035 | | | | | | | D/I | IOR | | 011 | | 0 | Z/C | | | | | | | | | | | | | | | i i | | | | | | Z/C | | | | | | | | | | | | | | | D/I | JSB | | 001 | | 1 | Z/C | | | | | | | | | | | | | | | D/I | JMP | | 010 | | 1 | | | | | | | | | | | | | | | | D/I | ISZ | | 011 | | 1 | Z/C | | | | | | | | | | | | | | | D/I | AD* | | 100 | | A/B | Z/C | | | | | | | | | | | | | | | D/I | CP* | | 101 | | A/B | Z/C | | | | | | | | | | | | | | | D/I | LD* | | 110 | | A/B | Z/C | | | | | | | | | | | | | | | D/I | ST* | | 111 | | A/B | Z/C | | T | | | | | r | <u></u> | | | | | | | 15 | 14 | 13 | | 12 | 11 | 10 | 9 | 8 | | 7 | | 6 | 5 | 4 | 3 | 2 | 1 | | 0 | | 0 | SRG | | 000 | | A/B | 0 | D/E | *LS | | | 000 | | †CLE | D/E | ‡sL* | *LS | | 000 | | | _ | | | | | A/B | Ō | D/E | *RS | | | 001 | | | D/E | • | *RS | | 001 | | | | | | | | A/B | Ö | D/E | R*L | | | 010 | | | D/E | | R*L | | 010 | | | | | | | | A/B | 0 | D/E | R*R | | | 011 | | | D/E | | R*R | | 011 | | | | | | | | A/B | 0 | D/E | *LR | | | 100 | | | D/E | | *LR | | 100 | | | | | | | | | | D/E | ER* | | | 101 | | | D/E | | ER* | | 101 | | | | | | | | A/B | 0 | D/E | EL* | | | | | | D/E | | EL* | | 110 | | | - 1 | | | | | A/B | 0 | D/E | 1 | | | 110 | | | | | | | | | | 1 | | | | | A/B | 0 | D/C | *LF | | | 111 | | | D/E | | *LF | | 111 | | | | | | | | NOP | 000 | | ļ | | | 000 | | | 000 | | | | 000 | | | 15 | 14 | 13 | | 12 | 11 | 10 | 9 | 8 | | 7 | .,,, | 6 | 5 | 4 | 3 | 2 | 1 | | 0 | | 0 | ASG | | 000 | | A/B | 1 | CL* | 01 | 1 | CLE | | 01 | SEZ | SS* | SL* | IN* | SZ* | | RSS | | _ | | | | | A/B | | CM* | 10 | - | CME | | 10 | | | | | | | | | - 1 | | | | | A/B | | cc* | 11 | - 1 | CCE | | 11 | | | | | | | | | | | | | | | | <u> </u> | 1 | | | | | | | | | | | | | 15 | 14 | 13 | | 12 | 11 | 10 | 9 | 8 | | 7 | | 6 | 5 | 4 | 3 | 2 | 1 | <del>,</del> | 0 | | 1 | IOG | | 000 | | | 1 | H/C | HLT | | | 000 | | - | | Sele | ct Code | <del></del> | | - | | | | • | | | | 1 | 0 | STF | | | 001 | | | | | | | | | | | | | | | | 1 | 1 | CLF | | | 001 | | | | | | | | | | - | | | | | | 1 | 0 | SFC | | | 010 | | | | | | | | | | İ | | | | | | 1 | 0 | SFS | | | 011 | | | | | | | | | | l | | | | | A/B | 1 | H/C | MI* | | | 100 | | | | | | | | | | l | | | | | A/B | 1 | H/C | LI* | | | 101 | | | | | | | | | | ŀ | | | | | A/B | 1 | H/C | OT* | | | 110 | | | | | | | | | | I | | | | | 0 | 1 | H/C | STC | | | 111 | | | | | | | | | | | | | | | 1 | 1 | H/C | CLC | | | 111 | | | | | | | | | | l | | | | | | 1 | 0 | STO | | | 001 | | | 000 | | | 001 | | | | l | | | | | | 1 | 1 | CLO | | | 001 | | | 000 | | | 001 | | | | | | | | | | 1 | H/C | soc | | | 010 | | | 000 | | | 001 | | | | | | | | | | 1 | H/C | SOS | | | 011 | | | 000 | | | 001 | | | | 15 | 14 | 13 | | 12 | 11 | 10 | 9 | 8 | | 7 | | 6 | 5 | 4 | 3 | 2 | 1 | | 0 | | 1 | EAG | | 000 | | MPY** | | 000 | - | 010 | * | | 4 | | 000 | | | 000 | | | | l | | | | | DIV** | | 000 | | 100 | | | | | 000 | | | 000 | | | | | | | | | DLD** | | 100 | | 010 | | | | | 000 | | | 000 | | | | | | | | | DST** | | 100 | | 100 | | | | | 000 | | 1 | 000 | | | | | | | | | ASR | | 001 | | 000 | | | | 0 | 1 | T | | | | | | l | | | | | ASL | | 000 | | 000 | | | | ŏ | 1 | 1 | | | | | | j | | | | | LSR | | 000 | | 000 | | | | 1 | Ó | | | umber | | | | | | | | | | | | | | | | | '1 | 0 | | | of — | | | | İ | | | | | LSL | | 000 | | 000 | | | | | | | | | | | | | | | | | RRR | | 001 | | 001 | | | | 0 | 0 | 1 | | bits | | | | | | | | | | | | | 11/1/1 | | | | | | | | | | | | | | | | | RRL | | 000 | | 001 | | | | | | <u>.</u> | | | | | | No. | oo: * | · A | . D | aor -1. | l | 1 | | | | | | + | <u> </u> | | his bit : | c rocui- | | | | | Note | | | | | ng to bit 1 | | 000 | | | # W . J . J . J . J . J . J . J . J . J . | | | L<br>CLE: | Only t | | s require | | | | | Note | | )/I, A/ | B, Z/C | , D/E | l | d: 0/1. | 000 | | | 4.9.44 | | | L<br>CLE:<br>SL*: | Only t | his bit a | s require | 11 (A/B | 3 as | | Table D-2. Extended Instruction Group Codes in Binary | | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |-------------------|----|----|----|----|-----|----|---|---|---|---|---|------------|-------------------------------------------|-------------|-----------------------|-----------------------| | SAX/SAY/SBX/SBY | 1 | 0 | 0 | 0 | A/B | 0 | 1 | 1 | 1 | 1 | 1 | 0 | X/Y | 0 | 0 | 0 | | CAX/CAY/CBX/CBY | 1 | 0 | 0 | 0 | A/B | 0 | 1 | 1 | 1 | 1 | 1 | 0 | X/Y | 0 | 0 | 1 | | LAX/LAY/LBX/LBY | 1 | 0 | 0 | 0 | A/B | 0 | 1 | 1 | 1 | 1 | 1 | 0 | X/Y | 0 | 1 | 0 | | STX/STY | 1 | 0 | 0 | 0 | 1 | 0 | 1 | 1 | 1 | 1 | 1 | 0 | X/Y | 0 | 1 | 1 | | CXA/CYA/CXB/CYB | 1 | 0 | 0 | 0 | A/B | 0 | 1 | 1 | 1 | 1 | 1 | 0 | X/Y | 1 | 0 | 0 | | LDX/LDY | 1 | 0 | 0 | 0 | 1 | 0 | 1 | 1 | 1 | 1 | 1 | 0 | X/Y | 1 | 0 | 1 | | ADX/ADY | 1 | 0 | 0 | 0 | 1 | 0 | 1 | 1 | 1 | 1 | 1 | 0 | X/Y | 1 | 1 | 0 | | XAX/XAY/XBX/XBY | 1 | 0 | 0 | 0 | A/B | 0 | 1 | 1 | 1 | 1 | 1 | 0 | X/Y | 1 | 1 | 1 | | ISX/I\$Y/DSX/DSY | 1 | 0 | 0 | 0 | 1 | 0 | 1 | 1 | 1 | 1 | 1 | 1 | X/Y | 0 | 0 | I/D | | JUMP INSTRUCTIONS | 1 | 0 | 0 | 0 | 1 | 0 | 1 | 1 | 1 | 1 | 1 | 1 | <i>\///</i> | Ō | 1 | 0 | | i | | | | | | | | | | | | JLY<br>JPY | = 0<br>= 1 | | | | | BYTE INSTRUCTIONS | 1 | 0 | 0 | 0 | 1 | 0 | 1 | 1 | 1 | 1 | 1 | 1 | 0 | | | | | :<br>-<br>-<br>- | | | | | | | | | | | | | LBT =<br>SBT =<br>MBT =<br>CBT =<br>SFB = | 1<br>1<br>1 | 1<br>0<br>0<br>1<br>1 | 1<br>0<br>1<br>0<br>1 | | BIT INSTRUCTIONS | 1 | 0 | 0 | 0 | 1 | 0 | 1 | 1 | 1 | 1 | 1 | 1 | 1 | | | | | | | | | | | | | | | | | | SBS =<br>CBS =<br>TBS = | 1 | 1<br>0<br>0 | 1<br>0<br>1 | | WORD INSTRUCTIONS | 1 | 0 | 0 | 0 | 1 | 0 | 1 | 1 | 1 | 1 | 1 | 1 | 1 | 1 | 1 | | | | | | | | | | | | | | | | | | MW =<br>VW = | | Table D-2. Extended Instruction Group Codes in Binary (Continued) | MEMORY EXPANSION | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |----------------------------------|----|-----|----|----|----------|----|---|------------|---|---|---|---|---|------------|------------|-----------| | DJP/DJS | 1 | 0 | 0 | 0 | 1 | 0 | 1 | 1 | 1 | 1 | 0 | 1 | 1 | | | | | | | | | | | | | | | | | | | DJP<br>DJS | | | | SYB/USB/PAB/PBB/SSM/JRS | 1 | 0 | 0 | 0 | 1 | 0 | 1 | 1 | 1 | 1 | О | 0 | 1 | | | | | | | | | | | | | | | | | | | SYB<br>USB | | | | | | | | | | | | | | | | | | PAB<br>PBB | = 0 | 1 ( | | | | | | | | | | | | | | | | SSM | = 1 | 0 | | V444 (V4 4 (V64 (V64 (4 5 4 | 1 | | 0 | 0 | | | | 1 | 1 | | T | | | JRS | - <br>-// | | | XMA/XLA/XSA/XCA/LFA | Ľ_ | L | | - | 0 | 0 | 1 | <u>L'</u> | 1 | | 0 | | 0 | XMA | <u> </u> | <u>//</u> | | | | | | | | | | | | | | | | XLA | = 1 | 0 | | | | | | | | | | | | | | | | XSA<br>XCA | = 1 | 1 | | MBI/MBF/MBW/MWI/MWF/MWW | 1 | I 0 | 0 | | 1 | 0 | 1 | 1 | 1 | | | 0 | 0 | LFA | = 1 | 1 | | IVIDI/IVIDE/IVIDAA/IVIAAI/IVIAAA | Ľ | Ľ | | | <u> </u> | | • | <u>l '</u> | • | • | | | | мві | <u>- 0</u> | 1 | | | | | | | | | | | | | | | | MBF | = 0 | 1 | | | | | | | | | | | | | | | | MBW<br>MWI | = 1 | 0 | | | | | | | | | | | | | | | | MWF<br>MWW | | | | SYA/USA/PAA/PBA | 1 | 0 | 0 | 0 | 0 | 0 | 1 | 1 | 1 | 1 | 0 | 0 | 1 | | | | | | | | | | | | | | | | | | | SYA<br>USA | | | | | | | | | | | | | | | | | | PAA<br>PBA | = 0 | 1 ( | Table D-2. Extended Instruction Group Codes in Binary (Continued) | • | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | |-------------------------|----------|----|----|----|----|----|---|---|---|---|----------|---|-----|--------|--------| | XMM/XMS/XMB/XLB | 1 | 0 | 0 | 0 | 1 | 0 | 1 | 1 | 1 | 1 | 0 | 1 | 0 | | | | XSB/XCB/LFB | <u> </u> | | | | | | | i | | | | | | | _ | | | | | | | | | | | | | | | XM | !!√I = | 0 | | | | | | | | | | | | | | | XM | 1S = | 0 | | | | | | | | | | | | | | | XM | IB = | 0 | | | | | | | | | | | | | | | XL | B = | 1 | | | | | | | | | | | | | | | XSI | В = | 1 | | | | | | | | | | | | | | | ХC | B = | 1 | | | | | | | | | | | | | | | LF | В = | 1 | | | | Г | | | | | | г | | | 1 | | | | _ | | RSA/RVA | 1 | 0 | 0 | 0 | 0 | 0 | 1 | 1 | 1 | 1 | 0 | 1 | 1 | | $\geq$ | | | | | | | | | | | | | | | ВС | A = | | | | | | | | | | | | | | | | | 'A = | | | | | | | | | | | | | | | | ηv | Α - | U | | RSB/RVB/SJP/SJS/UJP/UJS | 1 | 0 | 0 | 0 | 1 | 0 | 1 | 1 | 1 | 1 | 0 | 1 | 1 | | 7 | | | <u> </u> | | | | | | | | | | <u> </u> | | | | 2 | | | | | | | | | | | | | | | RS | В = | 0 | | | | | | | | | | | | | | | RV | в = | 0 | | | | | | | | | | | | | | | SJP | = | 1 | | | | | | | | | | | | | | | SJS | ; = | 1 | | | | | | | | | | | | | | | UJF | > = | 1 | | | | | | | | | | | | | | | | 3 = | 1 | | : | | | | | | |---|--|--|--|--|--| | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | : | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | ## APPENDIX ## ASSEMBLER OPERATIONS E The Assembler is a segmented program that executes under control of RTE in the User Program Area of main memory. The Assembler consists of a main program (ASMB) and five segments (ASMB0, ASMB1, ASMB2, ASMB3, and ASMB4). It resides on disc, and is read into main memory when called by the RU directive. Source programs, accepted from either an input device or a user file on the disc, are translated into absolute or relocatable object programs. ASMB will output the relocatable or absolute code to a disc file or device as specified by the binary output parameter when the assembler is invoked. If the source is on a device other than a disc file, it is stored on scratch tracks on the disc as it is being read. If there is insufficient space on the disc, the Assembler is suspended until more scratch tracks are available. # E-1. ON-LINE LOADING OF THE ASSEMBLER The following example illustrates the on-line loading of the Assembler in an RTE-IV Operating System. The size of the program should be increased to at least nine pages, with twelve pages being a recommended size. The extra space is needed by the assembler for its symbol table. | SZ,12 | *increase size of program | |-----------|-------------------------------------------------------------------------| | RE,%4ASMB | *relocate main module | | SE,%CLIB | *search compiler library | | RE,%4ASB0 | *relocate segment 0 | | SE,%CLIB | *search compiler library | | RE,%4ASB1 | *relocate segment 1 | | SE,%CLIB | *search compiler library | | | | | | | | | | | RE,%4ASB4 | *relocate segment 4 | | SE,%CLIB1 | *search compiler library | | EN | *end LOADR operation | | | RE,%4ASMB<br>SE,%CLIB<br>RE,%4ASB0<br>SE,%CLIB<br>RE,%4ASB1<br>SE,%CLIB | The Assembler must be loaded as a type 3 program which is also the default type used by the LOADR. #### RTE-L ON-LINE LOADING OF THE ASSEMBLER The following example illustrates the on-line loading of the Assembler in an RTE-L Operating System. # :RU,LOADR LOADR: LIB,\$CLIB LOADR: \$GMENTS,5 LOADR: REL,%ASMB \*use \$CLIB to do a search \*inform LOADER there is 5 segments \*relocate the main and five segments \*which are all in the same file. \*end the load process, libraries are \*now searched. #### E-2. ASSEMBLER OPERATION The RTE Assembler is initiated with a RU directive in the following form: ``` :RU,ASMB, _{input}^{source} \left[ \begin{smallmatrix} list \\ output \end{smallmatrix} \right] \left[ \begin{smallmatrix} binary \\ output \end{smallmatrix} \left[ \begin{smallmatrix} line \\ count \end{smallmatrix} \right] , options \right] \right] ``` where: source input Name of an FMGR file or a logical unit number of the device containing the Assembly source code; this entry must conform to the format required by the FMGR namr parameter. The source input must always be specified. If an interactive device is specified, the Assembler will print a right bracket (]) on the device as a prompt. It will then accept input a line at a time and output another prompt until an END statement is entered. list output Choose one of the following: (minus symbol)FMGR file namelogical unit numbernull (omitted) If the minus symbol is specified, and the source file name begins with an ampersand (&), the list file name will consist of the source file name with the ampersand replaced by an apostrophe ('). For example: &FIL1 source file name 'FIL1 list file name The list file is always forced to reside on the same cartridge (cartridge reference code) as the source file. If an FMGR file by this name does not already exist it is created. The created list file is given the same file security code as that of the source if it was specified in the source namr of the run sequence. If an FMGR file name is specified, it must conform to the format required by the FMGR namr parameter. The list file is created if it does not exist. If the file does exist, the first character in the file name must be an apostrophe ('); otherwise, an FMP -15 error will result indicating that the file name is illegal. If a logical unit number is specified, the list output is directed to that logical device. If this parameter is omitted, the logical unit of the interactive input device is assumed. Furthermore, if subsequent parameters are specified, the comma must be used as a parameter placeholder. binary output Choose one of the following: (minus symbol)FMGR file namelogical unit numbernull (omitted) If the minus symbol is specified, and the source file name begins with an ampersand (&), the binary file name will consist of the source file name with the ampersand replaced by a percent sign (%). For example: &FIL1 source file name %FIL1 binary file name This binary file is always forced to reside on the same cartridge (cartridge reference code) as the source file. If an FMGR file by this name does not already exist it is created. The created list file is given the same file security code as that of the source namr if it was specified in the source namr of the run sequence. If an FMGR file name is specified, it must conform to the format required by the FMGR namr parameter. The binary file is created if it does not exist. If the file exists, it is necessary that: - a. the first character of the file's name be a percent sign (%) or ! - b. the existing file be of the type specified in the namr parameter. If the file type is not declared in namr, the file's type must be type 5 or type 7, relocatable binary. If the above conditions are not met, an FMP-15 error will result. If a logical unit number is specified, the binary output is directed to that logical device. If this parameter is omitted, binary output is not produced. Furthermore, if subsequent parameters are specified, a comma must be used as a parameter placeholder. line count A decimal number which defines the number of lines per page for the list device. Specification of this parameter is optional. If it is omitted, 55 lines per page are assumed. options Up to six characters that select control function options. No commas are allowed within the option string. These characters are: A,R,B,L,Q,T,N,Z,C,F,X, and P (see Table 1-2 for an explanation of these options). If specified when the Assembler is run, these options replace (override) the options declared in the ASMB control statement. The P option has a special meaning in this context. If P is specified by itself, the Assembler will output the object code (if the binary output parameter has been specified) and the error reports and take no further actions. The type of object code is determined by the source program control statement. If the P option is specified with any other option, the P option is ignored. The R and A options cannot be overridden. Any attempt to do so will cause the Assembler to generate a CS error and abort. The R and A options are always determined by the source program control statement. #### Examples: \*RU,ASMB,&PROGA,-,- Schedules RTE ASMB to assemble the source code in file &PROGA. Listed output is directed to list file 'PROGA and binary relocatable code is directed to binary file %PROGA. The number of lines per list file defaults to 55. #### :RU,ASMB,&FIL1,'LIST Schedules RTE ASMB to assemble source file &FIL1. Listed output is directed to list file 'LIST. No binary relocatable code is generated. The number of lines per list file page defaults to 55. #### :RU,ASMB,&ABCD Schedules RTE ASMB to assemble source file & ABCD. Listed output defaults the user terminal. No binary relocatable code is generated. The number of lines per list file page defaults to 55. #### :RU,ASMB,&AAAA,-,-,28,LZ Schedules RTE ASMB to assemble source file &AAAA. Listed output is directed to list file 'AAAA. Binary relocatable code is directed to binary file %AAAA. The number of lines per list file page is 28. A listing will be produced because the L option has been specified. The Assembler will perform a selective assembly with respect to the Z option (see section IV on the IFZ and IFN pseudo-instructions). #### :RU,ASMB,&SFIL,-,-,,TQC Schedules RTE ASMB to assemble source file &SFIL. Listed output is directed to list file 'SFIL. Binary relocatable code is directed to binary file %SFIL. T will cause a symbol table listing to be output to the list file. Q will cause the memory reference instructions in the object code listing to appear as addresses only (the opcode will not appear in the listing). C will cause a cross-reference table to be output to the list file. $$:RU,ASMB,\&SFIL,-,-,P$$ The P option will cause the Assembler to produce only object code and error messages. It overrides the control options specified in the assembly language source program. #### E-3. MESSAGES DURING ASSEMBLY a. When the end of a source tape is encountered, the following message is output to the system console: LU #x is unavailable until the operator declares the associated EQT up using the RTE UP command: Assembly continues after the UP. More than one source tape can be assembled into one program by loading the next tape before giving the UP. b. If an FMP error occurs during the assembly, the Assembler will print the following message on the system console. /ASMB: $$FMP-nn$$ $\begin{cases} SOURCE \\ LIST \\ BINARY \end{cases}$ where: -nn is the FMP error number either SOURCE, LIST, or BINARY will be printed according to which file caused the error. The current assembly is aborted. c. The following message on the system console signifies the end of the assembly: d. If an error is found in the Assembler control statement, the following message is output to the system console. and the current assembly stops. e. If an end-of-file condition on the source input occurs before an END statement is found, the system console signals: /ASMB: \$END XEND and the current assembly stops. f. If the source input file does not exist, the system console signals: /ASMB: \$END NPRG and the current assembly stops. g. During pass 1, the Assembler will output error messages for each error it finds. Immediately above the error message, the number of the tape containing the error will be printed in the following form: #nnn The tape counter starts with one and increments by one whenever an end-of-tape condition occurs (using paper tape), or a blank card is encountered. When the counter increments, the numbering of the source statements starts over at one. h. Each error diagnostic printed in the program listing during pass two of the assembly is associated with a different message (printed on a separate line just above each diagnostic): PG ppp ppp is the page number (in the listing) of the previous error diagnostic. PG 000 is associated with the first error found in the program. i. At the end of pass 2, the Assembler will display the total error count on the system console in the following form: /ASMB: xxxx ERRORS TOTAL where xxxx is "NO" if 0 errors occurred, or the number of errors otherwise. The Assembler will also return the number of errors that occurred to the program that scheduled it as the first return parameter. This parameter may be retrieved using a call to the library subroutine RMPAR. # **MACHINE INSTRUCTION SET SUMMARY** APPENDIX F The following alphabetic list details the instructions that are available on the various HP 1000 computers. An asterisk in the L-SERIES column indicates that the instruction is implemented in software (see Section 3 paragraph 3-28). An "NA" indicates that the instruction is not available on that model of computer. It is assumed that the M, E and F-SERIES computers contain the Dynamic Mapping System instructions. Table F-1. M, E, F and L-Series Instruction Sets | | INSTRUCTION | M/E/F-SERIES | L-SERIES | |-----|---------------------------------------------|--------------|----------| | ABS | Define absolute value | | | | ADA | Add to A | | | | ADB | Add to B | | | | ADX | Add memory to X | | * | | ADY | Add memory to Y | | * | | ALF | Rotate A left 4 | | | | ALR | Shift A left 1, clear sign | | | | ALS | Shift A left 1 | | | | AND | "And" to A | | | | ARS | Shift A right 1, sign carry | | | | ASC | Generate ASCII characters | | | | ASL | Arithmetic long shift left | | | | ASR | Arithmetic long shift right | | | | | | | | | BLF | Rotate B left 4 | | | | BLR | Shift B left 1, clear sign | | | | BLS | Shift B left 1 | | | | BRS | Shift B right 1, carry sign | | | | BSS | Reserve block of storage starting at symbol | | | | BYT | Defines octal byte constants | | | | | | | | | CAX | Copy A to X | | * | | CAY | Copy A to Y | | * | | CBS | Clear bits | | * | | CBT | Compare bytes | | * | | CBX | Copy B to X | | * | | CBY | Copy B to Y | | * | | CCA | Clear and complement A (1's) | | | | CCB | Clear and complement B (1's) | | | | CCE | Clear and complement E (set E = 1) | | | | CLA | Clear A | | | | CLB | Clear B | | | Table F-1. M, E, F and L-Series Instruction Sets (Continued) | | INSTRUCTION | M/E/F-SERIES | L-SERIES | | |-----|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------|----------|--| | CLC | Clear I/O control bit | | | | | CLE | Clear E | | | | | CLF | Clear I/O flag | | | | | CLO | Clear overflow bit | | | | | CMA | Complement A | | | | | СМВ | Complement B | | | | | CME | Complement E | | | | | CMW | Compare words | | * | | | СОМ | Reserve block of common storage | | | | | CPA | Compare to A, skip if unequal | | | | | СРВ | Compare to B, skip if unequal | | | | | CXA | Copy X to A | | * | | | CXB | Copy X to B | | * | | | CYA | Copy Y to A | | * | | | CYB | Copy Y to B | • | * | | | - | Marine 1. | | | | | DBL | Define left byte (bits 8-15) address | | | | | DBR | Define right byte (bits 0-7) address | | | | | DEC | Define decimal constant | | | | | DEF | Define address | | | | | DEX | Define extended precision constant | | | | | DIV | Divide | | | | | DJP | Disable MEM and jump | | NA | | | DJS | Disable MEM and jump to subroutine | | NA | | | DLD | Double load | | | | | DST | Double store | | | | | DSX | Decrement X and skip if zero | | * | | | DSY | Decrement Y and skip if zero | | * | | | | | | | | | ELA | Rotate E and A left 1 | | | | | ELB | Rotate E and B left 1 | | | | | EMA | Extended Memory Area | | NA | | | END | Terminate program | | | | | ENT | Entry point | | | | | ERA | Rotate E and A right 1 | | | | | ERB | Rotate E and B right 1 | | | | | EQU | Equate symbol | | | | | EXT | External reference | | | | | | | | | | | FAD | Floating add | | * | | | FDV | Floating divide | | * | | | FIX | Convert floating-point to fixed-point | | * | | Table F-1. M, E, F and L-Series Instruction Sets (Continued) | | INSTRUCTION | M/E/F-SERIES | L-SERIES | |-----|--------------------------------------------------------------------|--------------|----------| | FLT | Convert fixed-point to floating-point | | * | | FMP | Floating multiply | | * | | FSB | Floating subtract | | * | | HED | Print heading at top of each page | | | | HLT | Halt | | | | IFN | When N appears in Control statement, assemble ensuing instructions | | | | IFZ | When Z appears in Control statement, assemble ensuing instructions | | | | INA | Increment A by 1 | - | | | INB | Increment B by 1 | | | | IOR | Inclusive "or" to A | | | | ISX | Increment X and skip if zero | | * | | ISY | Increment Y and skip if zero | | * | | ISZ | Increment, then skip if zero | | | | JLY | Jump and load Y | | * | | JMP | Jump | | | | JPY | Jump indexed by Y | | * | | JRS | Jump and restore status | | NA | | JSB | Jump to subroutine | | | | LAX | Load A from memory indexed by X | | * | | LAY | Load A from memory indexed by Y | | * | | LBT | Load byte | | * | | LBX | Load B from memory indexed by X | | * | | LBY | Load B from memory indexed by Y | | * | | LDA | Load into A | | | | LDB | Load into B | | | | LDX | Load X from memory | | * | | LDY | Load Y from memory | | * | | LFA | Load fence from A | | NA | | LFB | Load fence from B | | NA | | LIA | Load into A from I/O channel | | | | LIB | Load into B from I/O channel | | | | LSL | Logical long shift left | | | | LSR | Logical long shift right | | | | LST | Resume list output (follows a UNL) | | | | MBF | Move bytes from alternate map | | NA | | МВІ | Move bytes into alternate map | | NA | | MBT | Move byte | | * | Table F-1. M, E, F and L-Series Instruction Sets (Continued) | INSTRUCTION Many bytes within alternate man | | M/E/F-SERIES | L-SERIES | |----------------------------------------------|---------------------------------------|--------------|----------| | MBW | Move bytes within alternate map | | NA | | MIA | Merge (or) into A from I/O channel | | | | MIB | Merge (or) into B from I/O channel | | | | MIC | Define jump to user microcode | | | | MPY | Multiply | | | | MVW | Move words | | × | | MWF | Move words from alternate map | | NA | | MWI | Move words into alternate map | | NA | | MWW | Move words within alternate map | | NA | | NAM | Name relocatable program | | | | NOP | No operation | | | | | The operation | | | | OCT | Define octal constant | | | | ORB | Establish origin in base page | | | | ORG | Establish program origin | | | | ORR | Reset program location counter | | | | OTA | Output from A to I/O channel | | | | ОТВ | Output from B to I/O channel | | | | | | | | | PAA | Load/store Port A map per A | | NA | | PAB | Load/store Port A map per B | | NA | | PBA | Load/store Port B map per A | | NA | | PBB | Load/store Port B map per B | | NA | | | | | | | RAL | Rotate A left 1 | | | | RAM | Generate executable jump to microcode | | | | RAR | Rotate A right 1 | | | | RBL | Rotate B left 1 | | | | RBR | Rotate B right 1 | | | | REP | Repeat next statement | | | | RPL | Replace instruction definition | | | | RRL | Rotate A and B left | | | | RRR | Rotate A and B right | | | | RSA | Read status register in A | | NA | | RSB | Read status register into B | | NA NA | | RSS | Reverse skip sense | | | | RVA | Read violation register into A | | NA | | RVB | Read violation register into B | | NA NA | | | | | | | SAX | Store A into memory indexed by X | | * | | SAY | Store A into memory indexed by Y | | * | Table F-1. M, E, F and L-Series Instruction Sets (Continued) | | INSTRUCTION | M/E/F-SERIES | L-SERIES | |-----|-----------------------------------------------|--------------|----------| | SBS | Set Bits | | * | | SBT | Store byte | | * | | SBX | Store B into memory indexed by X | | * | | SBY | Store B into memory indexed by Y | | * | | SEZ | Skip if $E = 0$ | | | | SFB | Scan for byte | | * | | SFC | Skip if I/O flag = 0 (clear) | | | | SFS | Skip if I/O flag = 1 (set) | | | | SJP | Enable System map and jump | | NA | | SJS | Enable System map and jump to subroutine | | NA | | SKP | Skip to top of next page | | | | SLA | Skip if LSB of $A = 0$ | | | | SLB | Skip if LSB of B = 0 | | | | soc | Skip if overflow bit = 0 (clear) | | | | sos | Skip if overflow bit = 1 (set) | | | | SPC | Space n lines | | | | SSA | Skip if sign A = 0 | | | | SSB | Skip if sign $B = 0$ | | | | SSM | Store status register in memory | | NA | | STA | Store A | | | | STB | Store B | | | | STC | Set I/O control bit | | | | STF | Set I/O flag | | | | STO | Set overflow bit | | | | STX | Store X into memory | | * | | STY | Store Y into memory | | * | | SUP | Suppress list output of additional code lines | | | | SWP | Switch A and B | | | | SYA | Load/store System map per A | | NA | | SYB | Load/store System map per B | | NA | | SZA | Skip if $A = 0$ | | | | SZB | Skip if $B = 0$ | | | | | | | | | TBS | Test bits | | * | | | | | | | UJP | Enable User map and jump | | NA | | UJS | Enable User map and jump to subroutine | | NA | | UNL | Suppress list output | | | | UNS | Resume list output | | | | USA | Load/store User map per A | | NA | | USB | Load/store User map per B | | NA | Table F-1. M, E, F and L-Series Instruction Sets (Continued) | | INSTRUCTION | M/E/F-SERIES | L-SERIES | |-----|--------------------------------------------|--------------|----------| | XAX | Exchange A and X | | * | | XAY | Exchange A and Y | | * | | XBX | Exchange B and X | | * | | XBY | Exchange B and Y | | * | | XCA | Cross compare A | | NA | | XCB | Cross compare B | | NA | | XIF | Terminate IFN or IFZ group of instructions | | | | XLA | Cross load A | | NA | | XLB | Cross load B | | NA | | XMA | Transfer maps internally per A | | NA | | XMB | Transfer maps internally per B | | NA | | XMM | Transfer map or memory | | NA | | XMS | Transfer maps sequentially | | NA | | XOR | Exclusive "or" to A | | | | XSA | Cross store A | | NA | | XSB | Cross store B | | NA | ## **ASSEMBLER ERROR MESSAGES** APPENDIX G Errors detected in the source program are indicated by a 1- or 2-letter mnemonic followed by the sequence number and the first 62 characters of the statement in error. The messages are printed on the list output device during the passes indicated. A message specifying the number of errors detected is printed on the system console device at the end of each pass. Error listings produced during Pass 1 are preceded by a number which identifies the source input file where the error was found. Pass 2 error messages are preceded by a reference to the previous page of the listing where an error message was written. The first error will refer to page "0". The error count at the end of Pass 2 is preceded by the page number in the listing where the final error was encountered. | Error Code | Pass | Description | |----------------------------|------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | CS | 1 | Control statement error: <ul><li>a. The control statement contained a parameter other than the legal set.</li><li>b. Both A and R were specified.</li><li>c. Both F and X were specified.</li></ul> | | DD | 1 | Doubly defined symbol: A name defined in the symbol table appears more than once as: a. A label of a machine instruction. b. A label of one of the pseudo operations: | | | | BSS DBL EMA DBR BYT EQU ASC ABS DEC OCT DEF Arithmetic subroutine call DEX | | | | <ul><li>c. A name in the Operand field of a COM or EXT statement.</li><li>d. A label in an instruction following a REP pseudo operation.</li><li>e. Any combination of the above.</li></ul> | | | | An arithmetic subroutine call symbol appears in a program both as a pseudo instruction and as a label. | | EN | 1 | The symbol specified in an ENT statement has already been defined in an EXT statement, or is a label for an EMA pseudo-instruction. | | EN UNDEF <symbol></symbol> | 2 | The entry point specified in an ENT statement does not appear in the label field of a machine or BSS instruction. The entry point has been defined in the Operand field of an EXT statement. | | IF | 1 | An IFZ or an IFN follows either an IFZ or an IFN without an intervening XIF. The second pseudo instruction is ignored. | | Error Code | Pass | Description | |---------------------|--------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | $\operatorname{IL}$ | 1 | Illegal instruction: | | | | <ul> <li>Instruction mnemonic cannot be used with type of assembly requested<br/>in control statement. The following are illegal in an absolute<br/>assembly.</li> </ul> | | | | NAM EXT EMA ENT COM Arithmetic subroutine calls | | | | b. The ASMB statement has an R parameter, and NAM has been detected after the first valid Opcode. | | | | c. An EMA pseudo-instruction is encountered more than once. | | | 1 or 2 | Illegal character: A numeric term used in the Operand field contains an illegal character (e.g., an octal constant contains other than $+$ , $-$ , or 0-7). This code may also appear following an M error for missing operands. | | LB | 1 | Missing label in an EQU, RPL or EMA pseudo-instruction. | | M | 1 or 2 | Illegal operand: | | | | a. Operand is missing for an Opcode requiring one. | | | | b. Operands are optional and omitted but comments are included for: | | | | END<br>HLT | | | | c. Operand is an external symbol or an indirect address for: | | | | DBL<br>DBR | | | | d. An absolute expression in one of the following instructions from a relocatable program is greater than 1777 <sub>8</sub> . | | | | Instructions referencing memory locations: | | | | DEF, DBL, and DBR<br>Arithmetic subroutine calls | | | | e. A negative operand is used with an Opcode other than ABS, DEX, DEC, OCT, and BYT. | | | | f. A character other than I follows a comma with operands which can be indirect. | | | | g. Operand is an indirect address when used with JPY. | | | | h. Using a literal as the second operand in the following instructions: | | | | TBS<br>SBS<br>CBS | | | | i. A character other than C follows a comma in certain I/O instructions. | | | | j. A relocatable expression in the Operand field of one of the following: | | | | ABS ASR RRL<br>REP ASL LSR | | | | SPC RRR LSL | | | | k. An ORG statement appearing in a relocatable program includes an expression that is common relocatable or absolute. | | | | | relocatable terms. A relocatable expression contains a mixture of program and common m. The literal, literal code, or type of literal is illegal for the operation code used (e.g., STA = B7). | Error Code | Pass | Description | | | | | |------------|--------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--| | 1 | | n. An integer expression in one of the following instructions does not meet the condition $1 \le n \le 16$ . The integer is evaluated modulo $2^4$ . | | | | | | | | ASR RRR LSR<br>ASL RRL LSL | | | | | | | | o. The value of an 'L' type literal is relocatable. | | | | | | | | p. The number of words, n, specified for an ASCII string definition, An, exceeds 28 decimal words. | | | | | | | | q. There is no comma after the first operand in an EMA or MIC pseudo-instruction. | | | | | | | | r. One or both of the operands $m_1$ and $m_2$ for the EMA instruction do not conform to the bounds specifications. | | | | | | NO | 1 or 2 | No origin definition: The first statement in the assembly containing a valid opcode following the ASMB control statement (and remarks and/or HED, if present) is neither an ORG nor a NAM statement. If absolute, the program is assembled starting at 2000; if relocatable, the program is assembled starting at zero. | | | | | | OP | 1 or 2 | Illegal Opcode preceding first valid Opcode. The statement being processed does not contain an asterisk in position one. The statement is assumed to contain an illegal Opcode; it is treated as a remarks statement: | | | | | | | | Illegal Opcode: A mnemonic appears in the Opcode field which is not valid. A word is generated in the object program. | | | | | | OV | 1 or 2 | Numeric operand overflow: The numeric value of a term or expression has overflowed its limit: | | | | | | | | $1 \ge N \ge 16$ Shift-Rotate Set | | | | | | | | 2 <sup>2</sup> -1 Input/Output, Overflow, Halt | | | | | | | | 2 <sup>10</sup> -1 Memory Reference (in absolute assembly) | | | | | | | | 2 <sup>15</sup> Data generated by DEC or DEX | | | | | | | | 2 <sup>15</sup> -1 DEF and ABS operands and expressions concerned with program location counter. | | | | | | | | $2^{16}-1$ OCT | | | | | | SO | | There are more symbols defined in the program than the symbol table can handle. | | | | | | SY | 1 or 2 | Illegal Symbol: A Label field contains an illegal character or is greater than 5 characters. A label with illegal characters may result in an erroneous assembly if not corrected. A long label is truncated on the right to 5 characters. | | | | | | | | Illegal Symbol: A symbolic term in the Operand field is greater than five characters; the symbol is truncated on the right to 5 characters. | | | | | | | | Too many control statements: The source file contains more than one control statement. The Assembler assumes that the second control statement is a label, since it begins in column 1. Thus, the commas are considered as illegal characters and the "label" is too long. The binary object program is not affected by this error. The first control statement processed is the one used by the Assembler. | | | | | | ŲN | 1 or 2 | Undefined Symbol: | | | | | | :<br> | | <ul> <li>A symbolic term in an Operand field is not defined in the Label field of<br/>an instruction or is not defined in the Operand field of a COM or EXT<br/>statement.</li> </ul> | | | | | | | | b. A symbol appearing in the Operand field of one of the following | | | | | | | | pseudo operations was not defined previously in the source program: BSS ASC EQU ORG END EMA | | | | | | | | BSS ASC EQU ORG END EMA | | | | | ## **OUTPUT DATA FORMATS** **APPENDIX** ## NAM RECORD WORD 17 $(n \leq 60)$ #### **ENT RECORD** WORD 59 WORD 10 #### **EXT RECORD** WORD 7 WORD 60 #### **DBL RECORD** #### **END RECORD** 15,14 **EXPLANATION** RECORD LENGTH = 4 WORDS IDENT = 101 R: RELOCATION INDICATOR FOR TRANSFER ADDRESS - = 0 IF PROGRAM RELOCATABLE - = 1 IF BASE PAGE RELOCATABLE - = 2 IF COMMON RELOCATABLE - = 3 IF ABSOLUTE T: TRANSFER ADDRESS INDICATOR - = 0 IF NO TRANSFER ADDRESS IN RECORD - = 1 IF TRANSFER ADDRESS PRESENT #### **EMA RECORD** RELOCATABLE TRANSFER ADDRESS WORD 4 EXPLANATION RECORD LENGTH = 7 WORD IDENT = 110 SYMBOL ID. NO.: NUMBER ASSIGNED TO SYMBL FOR USE IN LOCATING REFER-ENCE IN BODY OF PROGRAM. #### LOADR/GENERATOR INFORMATION RECORD PACKED ASCII STRING UP TO 27 WORDS WORDS 4 THRU 30 #### ABSOLUTE FORMAT **EXPLANATION** RECORD LENGTH = NUMBER OF WORDS IN RECORD EXCLUDING WORDS 1 AND 2 AND THE LAST WORD. ABSOLUTE LOAD ADDRESS: STARTING ADDRESS FOR LOADING THE INSTRUCTIONS WHICH FOLLOW INSTRUCTION WORDS: ABSOLUTE INSTRUCTIONS OR DATA CHECKSUM: ARITHMETIC TOTAL OF ALL WORDS EXCEPT FIRST AND LAST On paper tape, each word represents two frames arranged as follows: # RTE CROSS REFERENCE TABLE GENERATOR APPENDIX ı This Real-Time Executive Operating System Cross Reference Table Generator routine (XREF) processes an assembler source program and provides a list of all symbols and symbol references used within the program. #### I-1. COMPUTER CONFIGURATION The routine requires a Real-Time Executive Operating System with logical unit 1 as the system console and a standard list device. XREF can be loaded on-line using the RTE LOADR. The LOADR SZ command should be used to increase the program size to reflect the number of symbols in the programs to be cross-referenced. The minimum recommended size is eight pages, with fourteen pages or more preferred to handle programs with large symbol tables. Refer also to the discussion on Bounds for a method to cross-reference only parts of the symbol table at a time. The following example presents a typical on-line loading of program XREF: | :RU,LOADR | | | |-----------|-----------|-----------------------------| | /LOADR: | SZ,12 | *size increased to 12 pages | | /LOADR: | RE,%4XREF | *relocate module | | /LOADR: | SE,%CLIB | *search compiler library | | /LOADR: | EN | end LOADR operations | On-line loading of the program XREF under the RTE-L operating system is accomplished by the following: | LIB, \$CLIB<br>RE, %XREF<br>END | *use \$CLIB to do a search *relocate module *end the load process, | |---------------------------------|--------------------------------------------------------------------| | | *libraries are now searched | ## I-2. FUNCTIONAL AND OPERATIONAL CHARACTERISTICS Source program input may come from: - a. An input unit specified by a logical unit number, - b. A disc file. - c. The temporary work area of the disc which was set up by the Assembler in a previous assembly. #### I-3. OUTPUT FORMAT The general format of the output list is: | SSSSS DDDDDD/TT RRRRR /TT | RRRRR /TT | |---------------------------|-----------| | RRRRR ;TT | RRRRR /TT | where: #### SSSSS is the symbol which may be any legal label to the assembler. #### DDDDD is the statement number in decimal in which the label was defined. It has a maximum value of 32767, when using the no tape number option, and a maximum value of 2047 when using tape numbers. #### Ţη is the decimal tape or file number (following a zero length record) with a maximum value of 16. #### RRRRR is the statement number in decimal in which the label was referenced. It has the same physical limits as the defining statement numbers. Note: The defined format and meaning of SSSSS, DDDDD, and TT are used in the following paragraphs. #### I-4. PSEUDO PROCESSING ORG, ORB, ORR, IFN, IFZ, XIF, MIC, and MIC-defined OPCODES are listed as: | **ORG | ****** | RRRRR/TT, | <br>RRRRR/TT | |-------|--------|-----------|--------------| | **ORB | ,, | " | ,, | | **ORR | ,, | " | ,, | | **IFN | ,, | " | ,, | | **XIF | ,, | ,, | ** | | **MIC | ,, | " | ,, | | **XYZ | ,, | " | ,, | (where 'XYZ' is a 'MIC'-defined opcode.) The defining statement number is replaced by a string of asterisks. #### I-5. DOUBLE DEFINED PROCESSING If a symbol has been defined more than once, it is listed in the symbol list in the following format: SSSSS ####### RRRRR/TT . . . . RRRRR/TT where: #### SSSSS is the symbol. #### I-6. UNDEFINED LABEL PROCESSING A symbol is referenced but not defined. The entry in the symbol list has the following format: SSSSS ???????? RRRRR/TT, ... RRRRR/TT The defining statement number is replaced by question marks. #### I-7. UNUSED LABEL PROCESSING If a symbol is defined but not referenced by a statement, the entry in the symbol list has the following format: @SSSSS DDDDD/TT The symbol is preceded by a "@". #### I-8. LITERAL PROCESSING If a literal of the type =L is referenced by a statement, the characters following the =L are handled as a normal symbol. If a literal of the type =A, =B, =D, or =F is referenced by a statement, the symbol list has the following format: LLLLL ..... RRRRR/TT, ... RRRRR/TT where: #### LLLLL is an exact copy of the literal. DDDDD, the defining statement number, is replaced by dots. If the literal is seven or more characters long: LLLLL is a maximum length of seven characters, the defining statement number does not have the first dot, and only the first seven characters are used. For example, =B12345 and =B123456 would be considered as the same literal =B12345 and would have the format. =B12345 ..... RRRRR/TT, ... RRRRR/TT #### I-9. OPERATION DIRECTIVE The operation directive for the cross-reference symbol table is: \*RU,XREF, $_{namr}^{source}$ [ $_{,namr}^{list}$ [,A[,B[,C]]]] where: source namr is an FMGR file or logical unit number containing the source code. If an interactive device is specified, XREF will print a right bracket (]) on the device as a prompt. It will then accept input a line at a time until an END statement is entered. list namr is an FMGR file or logical unit number to which XREF will output its listing. If not given, logical unit 6 is used. A minus symbol (-) may also be specified, in which case the same considerations apply to the list file as in the Assembler invocation (see Appendix E). A is the bounds specification. A=0 to specify no bounds. A=any non-zero character to request the entering of bounds from the system console to allow multiple passes of the cross-reference routine (see section I-10) for further explanation of bounds parameter). В is tape number or no tape number specification corresponding to the mode used in the assembly. B=0 to specify use of tape numbers and a tape length of less than 2038 statements. Note: A blank card inserted into a card deck before statement 2038 indicates an endof-tape. B=N to specify no tape numbers are to be used (sequence numbers can be as large as 32767). B=-N to cause XREF to number pages consecutively from the last RTE-ASMB page number (-N=-page number). C is the number of lines per page. C=0 to print 55 lines per page. C=N to print N lines per page. Note: The cross-reference routine can also be requested to run immediately after an assembly. XREF can be specified via a C parameter in the ASMB control statement. In this case, the following options are assumed: A=0,B=0,C=55. #### I-10. BOUNDS If the symbol table overflows when cross-referencing a program, XREF should be invoked using the bounds parameter. This capability allows the cross-reference table to be generated for only a specified set of symbols at a time. By entering repeated bounds specifications the entire cross-reference table may be listed. If the bounds parameter is specified, XREF will display the following query on the system console. /XREF: ENTER LIMITS <LH> or </E>?] The response to the limits query should be made by specifying either: LH or: $/\mathbf{E}$ where: L indicates the low bound H indicates the high bound /E terminates XREF If LH is specified, XREF will output to the list namr a cross-reference table for all symbols which are alphabetically between the values of L and H, inclusive. The standard ASCII ordering scheme is used, with blank being the lowest character and left arrow being the highest character. Following its output, XREF will repeat the query. If /E is entered, XREF will terminate. #### I-11. XREF ERROR MESSAGES Table I-1 contains a list of messages (and their meanings) the user may receive using the ON,XREF directive. The messages are printed as follows: /XREF: <message> Table I-1. XREF Messages | MESSAGE | MEANING | |---------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | END OF FILE | End of a user specified source file is reached before an END instruction is found. The XREF routine terminates. | | TABLE OVERFLOW | XREF routine does not have enough core space for the table entries. The XREF routine can be made to run with the option for specifying lower and upper bounds and use of multiple passes. | | /XREF: \$END <****> | Termination Message. Absolute assembly sources appear as shown. Relocatable sources contain NAM symbols: <name>.</name> | | ENTER LIMITS OR /E | A request is made to enter XREF bound limits from the system teleprinter. | | NO SOURCE | The Logical Source is not defined, or for RTE: $A=0$ . The XREF routine terminates. | | > 16 TAPE\$!! | More than 16 tapes or zero-length records have been encountered. XREF terminates. | #### I-12. SAMPLE CROSS-REFERENCE GENERATION The following pages show a sample Assembler program using cross-reference generation. ``` PAGE 0001 #01 1:30 PM TUE., 6 DEC., 1977 0001 ASMB,R,L,T,Z,C # 002 DO 0019 THREE OCT 3 START R 000000 AGAIN R 000002 LOOP R 000005 NEXT R 000011 NOUSE R 000012 R 000013 ADD ADDR R 000016 TIMES R 000017 THREE B 000000 OWT B 000001 INIT R 000020 COUNT R 000026 ONE R 000027 DNUM B 000002 R 000031 MUM HERE R 000043 **0001 ERRORS PASS#1 **RTE ASMB 92067-16011** ``` ``` 1:30 PM TUE., 6 DEC., 1977 PAGE 0002 #01 ASMB,R,L,T,Z,C 0001 DO-NOTHING USEFUL NAM EXAMP 0002 00000 START NOP 00000 000000 0003 JSB INIT 0004 00001 016020R 00002 062017R AGAIN LDA TIMES 0005 SET COUNTER FOR LOOP. STA COUNT 00003 072026R 0006 LDA = D123 INITIALIZE FIRST VALUE 00004 062043R 0007 00005 172016R LOOP STA ADDR,I SAVE VALUE 0008 ADA =B123456 CALCULATE NEXT VALUE 0009 00006 042044R ISZ ADDR 0010 00007 036016R BUMP COUNT ISZ COUNT 00010 036026R 0011 REPEAT UNTIL DONE JMP LOOP 00011 026005R NEXT 0012 0013 00012 062017R NOUSE LDA TIMES IFN 0014 ONE IF BY 'N' ADD ADA ONE 0015 XIF 0016 IFZ 0017 TWO IF BY 'Z' ADA TWO 0018 00013 040001B ADD XIF 0019 STA TIMES 00014 072017R 0020 SECOND TAPE JMP AGAIN 00015 026002R 0001 DRG NEXT 0002 00011 00011 026002R JMP AGAIN 0003 ORR 0004 00016 0005 00016 000000 ADDR NOP 00017 000000 TIMES NOP 0006 ORB 0007 00000 THREE DEC 3 00000 000003 8000 DEC 2 0009 00001 000002 0010 00020 ORR NOP 0011 00020 000000 INIT 0012 00021 060002B LDA DNUM STA ADDR 0013 00022 072016R PG 000 UN 0014 LDA NEG10 00023 062000 LDA NEG10 0014 STA TIMES 0015 00024 072017R JMP INIT, I 0016 00025 126020R 00026 000000 COUNT NOP 0017 00027 000001 ONE DCT 1 0018 00030 000003 THREE OCT 3 0019 ORB 0020 00002 DEF NUM 00002 000031R DNUM 0021 ORR 0022 00031 00031 000000 NUM BSS 10 0023 00043 HERE EQU * 0024 00043 000173 00044 123456 END START 0025 PG 002 ``` \*\*0002 ERRORS \*TOTAL \*\*RTE ASMB 92067-16011\*\* ``` PAGE 0003 EXAMP DO-NOTHING USEFUL CROSS-REFERENCE SYMBOL TABLE 1:30 PM TUE., 6 DEC., 1977 **IFN ****** 00014/01 **IFZ ****** 00017/01 **ORB ****** 00007/02 00020/02 **DRG ****** 00002/02 **ORR ****** 00004/02 00010/02 00022/02 **XIF ******* 00016/01 00019/01 =B12345 ..... 00009/01 =D123 ...... 00007/01 ADD ####### 00015/01 00018/01 ADDR 00005/02 00008/01 00010/01 00013/02 AGAIN 00005/01 00001/02 00003/02 COUNT 00017/02 00006/01 00011/01 DNUM 00021/02 00012/02 @HERE 00024/02 INIT 00011/02 00004/01 00016/02 LOOP 00008/01 00012/01 NEG10 ???????? 00014/02 NEXT 00012/01 00002/02 @NOUSE 00013/01 NUM 00023/02 00021/02 ONE 00018/02 00015/01 START 00003/01 00025/02 THREE ####### 00008/02 00019/02 TIMES 00006/02 00005/01 00013/01 00020/01 00015/02 TWO 00009/02 00018/01 ``` ## **INDEX** | ABS, 4-12, B-9, C-1 | CLE, 3-4, B-3, B-4, C-1 | |----------------------------------------------------|--------------------------------------------------| | Absolute Expressions, 2-4 | Clear Flag Indicator, 2-7 | | ADA, 3-1, B-2, C-1 | CLF, 3-8, B-6, C-1 | | ADB, 3-1, B-2, C-1 | CLO, 3-8, B-6, C-1 | | Add Instructions, 3-1 | CMA, 3-4, B-4, C-1 | | Address Definition Pseudo Instruction, 4-11 | CMB, 3-4, B-4, C-1 | | Address Expressions, 2-4 | CME, 3-4, B-4, C-1 | | Addressing | CMW, 3-2, B-2, C-1 | | Indirect, 2-6 | COM, 4-5, B-9, C-1 | | Memory, 1-2 | Comments Field, 2-7 | | Symbolic, 1-1 | Common, 4-7 | | ADX, 3-7, B-5, C-1 | Computer Configuration, I-1 | | ADY, 3-7, B-5, C-1 | Consolidated Coding Sheets, D-1 | | ALF, 3-4, B-3, C-1 | | | | Control Statement 1.2 | | Alphabetic List of Instructions, C-1 | Country Program I section 1.2 | | ALR, 3-4, B-3, C-1 | Counter, Program Location, 1-2 | | ALS, 3-4, B-3, C-1 | CPA, 3-2, B-2, C-1 | | Alter-Skip Instructions, 3-4 | CPB, 3-2, B-2, C-1 | | AND, 3-2, B-2, C-1 | Cross-Reference Table (XREF), RTE, I-1 | | Arithmetic Subroutine Calls, 4-20 | CXA, 3-5, B-5, C-1 | | ARS, 3-4, B-3, C-1 | CXB, 3-5, B-5, C-1 | | ASC, 4-14, B-10, C-1 | CYA, 3-5, B-5, C-1 | | ASL, 3-9, B-6, C-1 | CYB, 3-5, B-5, C-1 | | ASMB Statement, 1-3 | DBL, 4-13, B-10, C-1 | | ASR, 3-9, B-6, C-1 | DBR, 4-13, B-10, C-1 | | Assembler Control Pseudo Instructions, 4-1 | DEC, 4-14, B-10, C-1 | | Assembler Error Messages, G-1 | DEF, 4-11, B-9, C-1 | | Assembly Listing Control Pseudo Instructions, 4-22 | Define User Instruction Pseudo Instruction, 4-23 | | Assembly Options, 1-3 | Delimiters, Field, 2-1 | | Asterisk, 2-2, 2-3, 2-4 | DEX, 4-17, B-10, C-1 | | | DEY, 4-17, B-10, C-1 | | BCD-ASCII Conversion, A-4 | DIV, 3-9, B-6, C-1 | | Binary Output, 1-3 | DJP, 3-12, B-7, C-1 | | Bit Processing Instructions, 3-3 | DJS, 3-12, B-7, C-1 | | BLF, 3-4, B-3, C-1 | DLD, 3-9, B-6, C-1 | | BLR, 3-4, B-3, C-1 | DST, 3-9, B-6, C-1 | | BLS, 3-4, B-3, C-1 | DSX, 3-6, B-5, C-1 | | Bounds, I-2 | DSY, 3-6, B-5, C-1 | | BRS, 3-4, B-3, C-1 | Dynamic Mapping System, 3-10 | | BSS, 4-19, B-10, C-1 | Dynamic mapping bystem, 5-10 | | BYT, 4-19, B-10, C-1 | EAU Instructions, 3-9 | | | ELA, 3-4, B-3, C-1 | | Byte Processing Instructions, 3-2 | ELB, 3-4, B-3, C-1 | | | EMA, 4-19, B-10, C-1 | | CAX, 3-5, B-5, C-1 | END, 4-5, B-9, C-1 | | CAY, 3-5, B-5, C-1 | ENT, 4-7, B-9, C-1 | | CBS, 3-4, B-3, C-1 | ERA, 3-4, B-3, C-1 | | CBT, 3-3, B-3, C-1 | ERB, 3-4, B-3, C-1 | | CBX, 3-5, B-5, C-1 | Error Messages, Assembler, G-1 | | CBY, 3-5, B-5, C-1 | EQU, 4-13, B-10, C-1 | | CCA, 3-4, B-4, C-1 | Evaluation of Expressions, 2-4 | | CCB, 3-4, B-4, C-1 | Expression Operators, 2-4 | | CCE, 3-4, B-4, C-1 | Expression Terms, 2-4 | | Character Set, HP Computer Systems, 2-1, A-1 | <del>-</del> | | | Expressions | | CLA, 3-4, B-4, C-1 | Expressions Absolute, 2-4 | | CLA, 3-4, B-4, C-1<br>CLB, 3-4, B-4, C-1 | Expressions Absolute, 2-4 Evaluation of, 2-4 | | EXT, 4-7, B-9, C-1 | JLY, 3-7, B-5, C-2 | |--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------------------------------------------| | Extended Arithmetic Unit Instructions, 3-9 | JMP, 3-1, B-2, C-2 | | | JPY, 3-7, B-5, C-2 | | FAD, 3-10, B-7, C-1 | JRS, 3-12, B-7, C-2 | | FDV, 3-10, B-7, C-1 | JSB, 3-1, B-2, C-2 | | | Jump Instructions, 3-1 | | Fences, 3-18 | oump msu actions, 5-1 | | Field Delimiters, 2-1 | T.O. ' | | FIX, 3-10, B-7, C-1 | L-Series | | Flag, I/O Interrupt, 2-7 | Systems, 1-1 | | Floating Point Instructions, 3-10 | Instruction Replacements, 3-18 | | FLT, 3-10, B-7, C-1 | Label Field, 2-1 | | FMP, 3-10, B-7, C-1 | LABEL Symbol, 2-1 | | Format, Replacement, 3-19 | LAX, 3-6, B-5, C-2 | | FSB, 3-10, B-7, C-1 | LAY, 3-6, B-5, C-2 | | | LBT, 3-3, B-3, C-2 | | GEN instruction, 4-21 | LBX, 3-6, B-5, C-2 | | , and the second | LBY, 3-6, B-5, C-2 | | Halt Instruction, 3-9, B-6, C-2 | LDA, 3-1, B-2, C-2 | | HED, 4-22, B-10, C-2 | LDB, 3-2, B-2, C-2 | | HLT, 3-9, B-6, C-2 | LDX, 3-6, B-5, C-2 | | 1111, 5 5, 5 6, 6 2 | LDY, 3-6, B-5, C-2 | | IFN, 4-4, B-9, C-2 | Length, Statement, 2-1 | | | | | IFZ, 4-4, B-9, C-2 | LFA, 3-12, B-7, C-2 | | INA, 3-5, B-4, C-2 | LFB, 3-13, B-7, C-2 | | INB, 3-5, B-4, C-2 | LIA, 3-8, B-6, C-2 | | Input | LIB, 3-8, B-6, C-2 | | Increment-Skip Instructions, 3-1 | List Output, 1-6 | | Index Register Instructions, 3-5 | Listing Control Pseudo Instructions, 4-22 | | Indicator, Clear Flag, 2-7 | Literals, 2-6 | | Indirect Addressing, 2-6 | LOD Instruction, 4-21 | | Input/output Instructions, 3-7 | Load Instructions, 3-1 | | Instructions | Location Counter, 1-2 | | Add, 3-1 | Logical Operations, 3-2 | | Alter-Skip, 3-4 | LSL, 3-9, B-7, C-2 | | Bit Processing, 3-3 | LSR, 3-9, B-7, C-2 | | Byte Processing, 3-2 | LST, 4-22, B-10, C-2 | | Dynamic Mapping, 3-10, 3-12 | , , | | EAU, 3-9 | Map Segmentation, 3-11 | | Extended Arithmetic Unit, 3-9 | MBF, 3-13, B-7, C-2 | | Floating Point, 3-10 | MBI, 3-13, B-7, C-2 | | Halt, 3-7, 3-9 | MBT, 3-3, B-3, C-2 | | Increment-Skip, 3-1 | MBW, 3-13, B-7, C-2 | | Index Register, 3-5 | MEM Violation, 3-12 | | Input/Output, 3-7, 3-8 | Memory Reference Instructions, 3-1 | | | | | I/O, 3-7 | MIA, 3-8, B-6, C-2 | | Jump, 3-1 | MIB, 3-8, B-6, C-2 | | Load, 3-1 | MIC, 4-23, B-10, C-2 | | Logical Operations, 3-2 | MPY, 3-9, B-6, C-2 | | Memory Reference, 3-1 | MVW, 3-2, B-2, C-2 | | No-Operation, 3-7 | MWF, 3-13, B-7, C-2 | | Overflow, 3-7, 3-9 | MWI, 3-14, B-7, C-2 | | Register Reference, 3-4 | MWW, 3-14, B-7, C-2 | | Shift-Rotate, 3-4 | | | Store, 3-1 | NAM, 4-1, B-9, C-2 | | Word Processing, 3-2 | No-Operation Instruction, 3-7 | | Interrupt Flag, I/O, 2-7 | NOP, 3-7, B-4, C-2 | | I/O Instructions, 3-7 | Numeric Terms, 2-4 | | I/O Interrupt Flag, 2-7 | , | | IOR, 3-2, B-2, C-2 | Object Program Linkage Pseudo Instructions, 4-5 | | ISX, 3-6, B-5, C-2 | OCT, 4-17, B-10, C-2 | | ISY, 3-6, B-5, C-2 | Opcode Field, 2-2 | | ISZ, 3-1, B-2, C-2 | Operand Field, 2-3 | | ,, <b>,,</b> | operation receipt | | i | | |---------------------------------------|---------------------------------------------| | Operation Directive, I-2 | RVA, 3-15, B-8, C-2 | | Operators, Expression, 2-4 | RVB, 3-15, B-8, C-2 | | Options, Assembly, 1-3 | | | ORB, 4-2, B-9, C-2 | SAX, 3-7, B-5, C-2 | | ORG, 4-2, B-9, C-2 | SAY, 3-7, B-5, C-2 | | ORR, 4-3, B-9, C-2 | SBS, 3-3, B-3, C-2 | | OTA, 3-8, B-6, C-2 | SBT, 3-3, B-3, C-2 | | OTB, 3-8, C-6, C-2 | SBX, 3-7, B-5, C-2 | | Output | SBY, 3-7, B-5, C-2 | | Binary, 1-3 | SEZ, 3-4, B-4, C-2 | | List, 1-6 | SFB, 3-3, B-3, C-2 | | Overflow Instructions, 3-8 | SFC, 3-8, B-6, C-2 | | Overnow instructions, 5-6 | SFS, 3-8, B-6, C-2 | | DAA 9 14 D 0 C 0 | Shift-Rotate Instructions, 3-4 | | PAA, 3-14, B-8, C-2 | | | PAB, 3-14, B-8, C-2 | SJP, 3-15, B-8, C-3 | | Paging, 1-1 | SJS, 3-15, B-8, C-3 | | Passes, 1-1 | SKP, 4-22, B-10, C-3 | | PBA, 3-14, B-8, C-2 | SLA, 3-4, 3-5, B-3, B-4, C-3 | | PBB, 3-14, B-8, C-2 | SLB, 3-4, 3-5, B-3, B-4, C-3 | | Power Fail Characteristics, 3-11 | SOC, 3-8, B-6, C-3 | | Processing | SOS, 3-9, B-6, C-3 | | Double Defined, I-1 | Source Program, 1-2, 1-3 | | Literal, I-2 | SPC, 4-22, B-10, C-3 | | Pseudo, I-1 | SSA, 3-5, B-4, C-3 | | Undefined Label, I-2 | SSB, 3-5, B-4, C-3 | | Unused Label, I-2 | SSM, 3-15, B-8, C-3 | | Program, Common, 4-7 | STA, 3-2, B-2, C-3 | | Program, Source, 1-2 | Statement | | Program Location Counter, 1-2 | Characteristics, 2-1 | | Program Relocation, 1-1, 1-2 | Length, 2-1 | | Protected Mode, 3-12 | STB, 3-2, B-2, C-3 | | Pseudo Instructions | STC, 3-8, B-6, C-3 | | | STF, 3-8, B-6, C-3 | | Address Definition, 4-11 | | | Arithmetic Subroutine Calls, 4-20 | STO, 3-8, B-6, C-3 | | Assembler Control, 4-1 | Storage Allocation Pseudo Instruction, 4-19 | | Assembly Listing Control, 4-22 | Storage Instructions, 3-1 | | Constant Definition, 4-14 | STX, 3-6, B-5, C-3 | | Define User Instruction, 4-23 | STY, 3-6, B-5, C-3 | | Linking, 4-5 | Summary of Instructions, B-1 | | Listing Control, 4-22 | SUP, 4-22, B-10, C-3 | | Object Program Linkage, 4-5 | SWP, 3-9, C-3 | | RTE-L, 4-21 | SYA, 3-15, B-8, C-3 | | Storage Allocation, 4-19 | SYB, 3-15, B-8, C-3 | | Symbol Definition, 4-11 | Symbol, Label, 2-1 | | | Symbol Definition Pseudo Instructions, 4-11 | | RAL, 3-4, B-3, C-2 | Symbols, 1-1 | | RAM, 4-24, B-10, C-2 | Symbol Table, 1-3 | | RAR, 3-4, B-3, C-2 | Symbolic Addressing, 1-1 | | RBL, 3-4, B-3, C-2 | Symbolic Terms, 2-2 | | RBR, 3-4, B-3, C-2 | SZA, 3-5, B-4, C-3 | | Register Reference Instructions, 3-4 | SZB, 3-5, B-4, C-3 | | Registers, Status and Violation, 3-11 | Tape Formats, H-1 | | Relocatable Expressions, 2-4 | Terms | | Relocation, Program, 1-2 | Numeric, 2-4 | | REP, 4-5, B-9, C-2 | Symbolic, 2-2 | | | Expression, 2-4 | | RPL, 4-10, B-9, C-2 | Expression, 2-4 | | RRL, 3-9, B-7, C-2 | TRS 3.3 B.3 C 3 | | RRR, 3-9, B-7, C-2 | TBS, 3-3, B-3, C-3 | | RSA, 3-15, B-8, C-2 | IIID 9 16 D 9 C 9 | | RSB, 3-15, B-8, C-2 | UJP, 3-16, B-8, C-3 | | RSS, 3-5, B-4, C-2 | UJS, 3-16, B-8, C-3 | | RTE-L Pseudo Instruction, 4-21 | UNL, 4-22, B-10, C-3 | #### Index UNS, 4-22, B-10, C-3 USA, 3-16, B-8, C-3 USB, 3-16, B-8, C-3 Word Processing Instructions, 3-2 XAX, 3-5, B-5, C-3 XAY, 3-5, B-5, C-3 XBX, 3-5, B-5, C-3 XBY, 3-5, B-5, C-3 XCA, 3-16, B-8, C-3 XCB, 3-16, B-8, C-3 XIF, 4-4, B-9, C-3 XLA, 3-17, B-8, C-3 XLB, 3-17, B-8, C-3 XMA, 3-17, B-8, C-3 XMB, 3-17, B-8, C-3 XMS, 3-17, B-8, C-3 XMS, 3-17, B-8, C-3 XOR, 3-2, B-2, C-3 XSA, 3-18, B-8, C-3 XSB, 3-18, B-8, C-3 ## READER COMMENT SHEET RTE-IV ASSEMBLER Reference Manual 92067-90003 Address April 1980 Update No. \_\_\_\_\_ (If Applicable) We welcome your evaluation of this manual. Your comments and suggestions help us improve our publications. Please use additional pages if necessary. FROM: Name Company ### **BUSINESS REPLY MAIL** FIRST CLASS PERMIT NO. 141 CUPERTINO, CA. - POSTAGE WILL BE PAID BY - **Hewlett-Packard Company** Data Systems Division 11000 Wolfe Road Cupertino, California 95014 ATTN: Technical Marketing Dept. NO POSTAGE NECESSARY IF MAILED IN THE UNITED STATES **FOLD** FOLD