Prime Computer, Inc. ## FDR3059-101B **Assembly Language** Programmer's Guide Rev. 16.3 The Assembly Language Programmer's Guide ## The Assembly Language Programmer's Guide by Rosemary Shields Published by Prime Computer, Incorporated Technical Publications Department 145 Pennsylvania Avenue, Framingham, MA 01701 Copyright © 1981 by Prime Computer, Inc. Third Printing January 1981 All rights reserved. The information contained in this document is subject to change without notice and should not be construed as a commitment by Prime Computer, Incorporated. Prime Computer assumes no responsibility for any errors that may appear in this document. This document reflects the software as of Master Disk Revision Level 16. PRIMOS® is a trademark of Prime Computer, Inc. Credits. ## **Concept and Production** William I. Agush Typesetting. Allied Systems Covers. Mark-Burton Text. Eastern Graphics ## 1 INTRODUCTION Introduction 1-1 Organization and usage 1-1 Related documents 1-1 ## 2 CONVENTIONS Prime conventions 2-1 Instruction description conventions 2-1 Function group definitions 2-2 Table 2-1. Function definitions 2-3 Format definitions 2-3 Table 2-2. Format definitions 2-3 General data structure 2-3 Table 2-3. Data structures 2-4 Processor characteristic 2-5 Table 2-4. Processor characteristics 2-5 Terminal session example 2-5 ## 3 ASSEMBLING Invoking the Prime Macro Assembler (PMA) 3-1 File usage 3-1 Assembler messages 3-2 Listing format 3-2 Figure 3-1. A-Register details 3-3 Figure 3-2. Example of assembly listing 3-4 ## 4 LOADING R-MODE PROGRAMS Introduction 4-1 Using the loader under PRIMOS 4-1 Normal loading 4-1 Load maps 4-3 Loader concepts 4-4 Figure 4-1. Examples of load maps 4-7 Command summary 4-8 ## **5** LOADING SEGMENTED PROGRAMS Introduction 5-1 Using SEG under PRIMOS 5-1 Normal loading 5-2 Load maps 5-3 Figure 5-1. Example of load map 5-5 Advanced SEG features 5-7 Command summary 5-8 SEG-level commands 5-9 LOAD subprocessor commands 5-10 MODIFY subprocessor commands 5-13 ## 6 EXECUTING Execution of unsegmented runfiles 6-1 Execution of segmented runfiles 6-2 Installation in the command UFD (CMDNC0) 6-2 Run-time error messages 6-5 ## 7 DEBUGGING Tools 7-1 Advanced debugging techniques 7-2 Debugging-PRIMOS severe errors 7-2 Memory overflow errors 7-3 ## **8** INTERFACING WITH THE SYSTEM LIBRARIES Table 8-1. System libraries 8-1 Figure 8-1. SR Subroutine CALL conventions 8-2 Figure 8-2. VI subroutine CALL conventions 8-3 ## 9 DATA AND INSTRUCTION FORMATS—SRVI Data structures 9-1 Processor characteristics 9-8 Instruction formats—I-mode 9-16 Table 9-1. Address formation special case selection 9-18 ## 10 MEMORY REFERENCE CONCEPTS (SRV) Background concepts 10-1 Table 10-1. Memory reference instruction format 10-2 Memory reference instruction formats 10-4 Table 10-2. V-mode two word memory reference 10-9 Addressing mode summaries and flow charts 10-10 Figure 10-1. 16S address calculation 10-11 Figure 10-2. 32S address calculation 10-13 Figure 10-3. 32R address calculation (1 of 5) 10-16 Figure 10-4. 32R address calculation (2 of 5) 10-17 Figure 10-5. 32R address calculation (3 of 5) 10 - 18Figure 10-6. 32R address calculation (4 of 5) 10-19 Figure 10-7. 32R address calculation (5 of 5) 10-20 Figure 10-8. 64R address calculation (1 of 5) 10-23 Figure 10-9. 64R address calculation (2 of 5) 10-24 Figure 10-10. 64R address calculation (3 of 5) 10-25 Figure 10-11. 64R address calculation (4 of 5) 10-26 Figure 10–12. 64R address calculation (5 of 5) 10–27 Figure 10–13. 64V address calculation (1 of 3) 10–31 Figure 10–14. 64V address calculation (2 of 3) 10–32 Figure 10–15. 64V address calculation (3 of 3) 10–33 Field operations—FIELD 11-15 Floating point arithmetic—FLPT 11-16 Table 11-3. Floating point exception codes 11-16 Table 11-4. Floating point mantissa and exponent ranges 11-17 ## 11 INSTRUCTION DEFINITIONS Addressing mode—ADMOD 11-1 Branch—BRAN 11-2 Character string operations—CHAR 11-5 Clear register—CLEAR 11-7 Decimal arithmetic—DECI 11-8 Table 11-1. Decimal data type 11-9 Table 11-2. Edit sub-operations 11-14 Key Manipulation—KEYS 11-31 Logical operations—LOGIC 11-32 Logical test and set—LTSTS 11-33 Machine control—MCTL 11-34 Move data—MOVE 11-39 Program control and jump—PCTLJ 11-43 Process exchange—PRCEX 11-49 Queue management—QUEUE 11-49 Shift group—SHIFT 11-50 Skip conditional—SKIP 11-53 Table 11-5. Combination skip group 11-55 ## 12 I-MODE INSTRUCTIONS Addressing mode—ADMOD 12-1 Branch—BRAN 12-1 Character operations—CHAR 12-3 Clear register and memory—CLEAR 12-14 Decimal arithmetic—DECI 12-5 Field Operations—FIELD 12-5 Floating point arithmetic—FLPT 12-6 Integer arithmetic—INT 12-9 Integrity check for hardware—INTGY 12-14 Input/output—I/O 12-14 Key manipulation—KEYS 12-14 Logical operations—LOGIC 12-15 Logical test and set-LTSTS 12-16 Machine control—MCTL 12-17 Move data—MOVE 12-17 Program control and jump—PCTLJ 12-19 Process exchange—PRCEX 12-10 Queue management—QUEUE 12-10 Shift—SHIFT 12-21 ## 13 INSTRUCTION SUMMARY CHART Instruction summary 13-1 ## 14 LANGUAGE STRUCTURE Introduction 14-1 Lines 14-1 Statements 14-1 Figure 14-1. PMA statements 14-2 Figure 14-2. PMA line format 14-3 Memory reference instruction format 14-5 Instruction formats—I-Mode 14-5 Table 14-1. Assembler formats 14-7 How to write V or I mode code in PMA 14-8 ## 15 DATA DEFINITION Table 15-1. Numeric constants 15-2 Terms 15-5 Figure 15-1. Floating point data formats 15-6 Table 15-2. Modes 15-8 Expressions 15-8 Literals 15-10 Assembler attributes 15-11 ## **16** PSEUDO OPERATIONS Introduction 16-1 Table 16-1. Pseudo-operation summary 16-2 Figure 16-1. Pseudo-operations 16-4 Assembly control psuedo-operations (AC) 16-5 Address definition pseudo-operations (AD) 16-7 Conditional assembly pseudo-operations (CA) 16-8 Data defining pseudo-operations (DD) 16-10 Listing control pseudo-operations (LC) 16-11 Literal control pseudo-operations (LT) 16-12 Loader control pseudo-operations (LO) 16-13 Macro definition pseudo-operations (MD) 16-16 Program linking pseudo-operations (PL) 16-18 Storage allocation pseudo-operations (SA) 16-20 Symbol defining pseudo-operations (SD) 16-20 ## 17 MACRO FACILITY Introduction 17-1 Macro definition 17-2 Macro calls 17-3 Nesting macros 17-5 Conditional assembly 17-6 Macro listing 17-6 ## 18 INTRODUCTION TO TAP, PSD, VPSD Using TAP 18-1 Table 18-1. Debugging command summary 18-1 Using PSD 18-3 Table 18-2. PSD/VPSD versions 18-3 Using VPSD 18-3 Command line format 18-4 Table 18-3. Input/output formats (PSD and VPSD) 18-5 ## 19 TAP COMMAND SUMMARY TAP command summary 19-1 Table 19-1. TAP terminators 19-1 Table 19-2. Keys 19-3 ## **20** PSD COMMMAND SUMMARY PSD command summary 20-1 Table 20-1. PSD terminators 20-1 Table 20-2. Key values: R and S mode 20-4 ## 21 VPSD COMMAND SUMMARY Table 21-1. VPSD terminators 21-1 Table 21-2. Key values: R and S modes 21-4 Table 21-3. Key values: V mode 21-5 ## A ASSEMBLER ATTRIBUTES **B** ASCII CHARACTER SET C ERROR MESSAGES ## OVERVIEW ## Introduction ## INTRODUCTION This document is a comprehensive user guide for the Prime Macro Assembler (PMA) programmer. In this one document you will find almost everything you will need to know to write, assemble, load, debug and execute an assembly language program. We assume the following background: you are an experienced assembly language programmer although you may be unfamiliar with Prime's PMA; and you have been introduced to Prime's PRIMOS operating system and its major utilities through the use of a high-level language such as FORTRAN and COBOL. (If not, we recommend you read one of our other language user guides before undertaking a PMA project.) ## ORGANIZATION AND USAGE This document is organized into five major parts: - Part 1. Overview and conventions (Sections 1 and 2) - Part 2. PMA Usage (Sections 3 through 8) - Part 3. Machine Formats and Instructions (Sections 9 through 13) - Part 4. PMA Reference (Sections 14 through 17) - Part 5. Debugging Utilities Reference (Sections 18 through 21) In addition to a tutorial section for the new PMA programmer (Part 2), it contains complete descriptions of: Machine instructions Data structures Assembler pseudo operations Assembler macro facilities TAP, PSD and VPSD debugging facilities ## **RELATED DOCUMENTS** The FORTRAN Programmer's Guide Reference Guide, System Architecture The New User's Guide to Editor and Runoff PRIMOS Commands Reference Guide Reference Guide. PRIMOS Subroutines PRIMOS Programmer's Companion FORTRAN Programmer's Companion Assembly Language Programmer's Companion Reference Guide, LOAD and SEG ## Conventions ## PRIME CONVENTIONS Symbols, abbreviations, special characters and conventions frequently used in this document are defined below. ## Prime filename conventions | Filename | Function | |------------|-------------------------| | Bfilename | Binary (object) file | | Lfilename | Listing file | | C_filename | Command file | | filename | Source file | | *filename | Saved (executable) file | | M_filename | Map file | | #filename | SEG runfile | ## Note Filenames may be a maximum of 32 characters. ## **Text conventions** An item in all capital letters must be included verbatim. Rust colored letters indicate acceptable abbreviations. In TAP, PSD and VPSD commands enter *only* the rust colored letters. A quote mark (apostrophe) preceding a number means octal. ## INSTRUCTION DESCRIPTION CONVENTIONS This section describes each of the instructions in the context of the mode where they are first used. To avoid duplicate descriptions while facilitating retrieval, each instruction is described once, but listed in I-mode if appropriate. ## Format illustration: ## Instruction summary and description conventions | A | A Register (16-bits) | |---------------|---------------------------------| | В | B Register (16 bits) | | L | L Register (A B) | | E | E Register (32-bits) | | F | Floating Point Register | | Н | Half Register (16-bits, I Mode) | | R | Full register (32-bits, I Mode) | | C | C-Bit in the keys | | L-bit | L-Bit in the Keys | | CC | Condition Codes | | LB | Link Base Register | | SB | Stack Base Register | | PB | Procedure Base Register | | XB | Temporary Base Register | | S | S-Mode | | R | R-Mode | | $\mathbf{V}$ | V-Mode | | I | I-Mode | | FAR | Field Address Register | | FLR | Field Length Register | | $\rightarrow$ | Replaces | | | | ## **FUNCTION GROUP DEFINITIONS** The instruction definitions are grouped by primary function, such as integer arithmetic. Table 2-1 below contains the definitions for all the function groups and modes. If you wish to find a particular instruction, Section 13 contains an alphabetic list. | Table 2-1. Function Definitions | | | | | | |---------------------------------|---|---|---------------------------|---|--| | Definition | S | R | V | I | | | Addressing Mode | X | X | X | X | | | Branch | | | X | X | | | Character | | | X | X | | | Clear field | X | X | X | | | | Decimal Arithmetic | | | X | X | | | Field Register | | | X | X | | | Floating Point Arithmetic | | X | X | X | | | Integer Arithmetic | X | X | X | X | | | Integrity | X | X | X | X | | | Input/Output | X | X | X | X | | | Keys | X | X | X | X | | | Logical Operations | X | X | X | X | | | Logical Test and Set | X | X | X | X | | | Machine Control | X | X | $\mathbf{X}_{\mathbf{x}}$ | X | | | Move | X | X | X | X | | | Program Control and Jump | X | X | X | X | | | Process Exchange | | | X | X | | | Queue Control | | | X | X | | | Shift | X | X | X | X | | | Skip | X | X | X | X | | ## FORMAT DEFINITIONS Each instruction has a format. The formats and their meaning are summarized in Table 2-2. The specific bit definitions are defined in Section 9—Data and Instruction Formats and Section 10—Memory Reference Concepts. | able 2-2. Format De | efinitions | | | | | |---------------------|-----------------------------------------|---|---|--------------|---| | Mnemonic | Definition | S | R | $\mathbf{V}$ | I | | GEN | Generic | X | X | X | X | | AP | Address Pointer | | | X | X | | BRAN | Branch | | | X | | | IBRN | Branch I-mode | | | | X | | CHAR | Character | | | X | X | | DECI | Generic Decimal | | | X | X | | PIO | Programmed I/O | X | X | X | X | | SHFT | Shift | X | X | X | X | | MR | Memory Reference –<br>Non I-mode | X | X | X | | | MRFR | Memory Reference –<br>Floating Register | | | | X | | MRNR | Memory Reference<br>Non Register | | | | X | | RGEN | Register Generic | | | | X | ## **GENERAL DATA STRUCTURES** Table 2-3. Data Structures—summarizes all the data structures manipulated by instructions. | Class | S | R | V | I | |-----------------------------------------------|--------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------|---------------------------------| | <b>Integer (Unsigned)</b><br>16-bit<br>32-bit | X | X | X<br>X | X<br>X | | Integer (Signed)<br>16-bit<br>31-bit | X<br>X | X<br>X | X | X | | 32-bit | | | $X_{\alpha}$ | X | | Floating Point | | | | | | 32-bit<br>64-bit | | X | X | $\frac{\mathbf{X}}{\mathbf{X}}$ | | | | Δ | X | $oxed{X}$ | | Decimal | | | | | | Character String | | | X | | | Word<br>16-bit<br>32-bit | | X | X | | | Halfword - 16 bit | | | | | | Byte | $\mathbf{x}$ | Χ | X | | | Indirect Pointer (IP) | | | | | | 16-bit<br>32-bit<br>48-bit | | X | X<br>X<br>X | X | | Address Pointer (AP) | | | X | | | Stacks | | 化物物质的<br>医性压缩 | | | | Segment Header<br>Frame Header | | | X<br>X | | | Argument Template | | and 等。<br>and 等<br>and and | Χ | | | Entry Control Block | | (2) 10 日本 | Χ | | | Queue Control Block | | | X | | ## PROCESSOR CHARACTERISTICS Table 2-4, Processor Characteristics, lists the program visible portions of the hardware. | able 2-4. Processor Characteristic | cs | | | | | |------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---|---|---|--| | Class | <b>S</b> | R | V | I | | | Registers | | | | | | | S, R mode | $\mathbf{X}$ | X | | | | | V, I mode | | | X | X | | | Field Registers | | | X | Χ | | | Floating Registers | | Χ | X | Χ | | | Keys | | | | | | | S, R mode | X | Χ | | | | | V. I mode | | | X | X | | | C-Bit | | Χ | Χ | Χ | | | L-Bit Joseph San All Color | | | X | X | | | Condition Codes | ing the second reserving the second reserving to s | | X | X | | | Modals | | | X | X | | ## SAMPLE TERMINAL SESSION ``` ***** FIRST, CREATE THE FILE ***** OK, ED GO INPUT EDIT TAB 10 15 25 INPUT \SEG \RLIT STR\LDA\='456 \STA\BUFF1 \STA\BUFF2 \PRTN ***** DATA AREA ***** \DYNM\STCK(1) \LINK BUFF1\BSS\1 BUFF2\BSS\1 \ECB\STR \END EDIT FILE TTY **** **** ASSEMBLE THE FILE **** **** ``` 1 March, 1979 ``` OK, PMA TTY GO ØØØØ ERRORS (PMA-REV 15.0) **** ***** PMA LISTING ***** **** OK, SLIST L TTY GO SEG SEG (ØØØ1) (ØØØ2) RLIT LDA = '456 02.000005 (ØØØ3) STR 000000: STA BUFF1 (0004) Ø4.000400L 000001: LDA STCK 02.000012S (ØØØ5) ØØØØØ2: STA BUFF2 Ø4.000401L (0006) 000003: PRTN 000611 (ØØØ7) 000004: (ØØØ8) ***** DATA AREA ***** DYNM STCK(1) 000012 (0009) LINK (0010) BSS 1 (ØØ11) BUFF1 ØØØ4ØØ> BSS 1 (ØØ12) BUFF2 000401> ECB STR (\emptyset\emptyset13) ØØØØØØ 000402> 000014 000011 ØØØØØØ 177400 014000 END (\emptyset\emptyset14) 000422 00.000456A 000005: STACK ØØØØ13 PROC ØØØØØ6 LINK ØØØØ22 TEXT SIZE: 000400L 0004 ØØ11 BUFF1 000401L 0006 ØØ12 BUFF2 øøø9 000012S 0005 STCK 000000 0003 ØØ13 STR ØØØØ ERRORS (PMA-REV 15.Ø) **** ***** LOAD THE FILE ***** **** OK, SEG GO # LOAD SAVE FILE TREE NAME: $TTY1 $ LOAD B TTY LOAD COMPLETE $ SAVE ``` ``` $ MAP *START 000000 000000 *STACK 004001 001006 *SYM 000003 SEG. # TYPE LOW HIGH TOP ØØ4ØØ1 PROC## 001000 001005 001005 004002 DATA 000002 ØØØØ21 000021 ROUTINE ECB PROCEDURE ST. SIZE LINK FR. #### 4002 000002 4001 001000 000014 000022 4002 177400 DIRECT ENTRY LINKS COMMON BLOCKS OTHER SYMBOLS **** **** EXECUTE THE PROGRAM ***** $ EXECUTE ACCESS VIOLATION ***** ERROR - CALL VPSD ***** ER! VPSD GO $SN 4001 $A 1000:S 4001/1000 LDA# 1005 4001/1001 STA# LB%+ 400 4001/1002 LDA# SB%+ 12 4001/1003 STA# LB%+ 401 4001/ 1004 PRTN 4001/ 1005 DAC 456 4001/ 1006 HLT $B 1000 $R 1000 4001/ 1000: LDA# 1005 A=0 B=0 X=0 K=14000 R=0 Y=12614 $B 1004 $PR 4001/1004: PRTN A=0 B=0 X=0 K=14000 R=0 Y=12614 $PR ACCESS VIOLATION ER! ED TTY **** ***** PROBLEM WAS INCORRECT ECB - NOTE THAT LOAD MAP *START **** ENTRY HAD A ZERO VALUE. MAIN PROGRAM NEEDS END OPERAND **** REFERENCING THE ECB LABEL. **** GO ``` 1 March, 1979 EDIT ``` TAB 10 15 25 L END END R \END\ECB1 N-1 ECB STR C / /ECB1/ ECB1 ECB STR FILE OK, PMA TTY GO ØØØØ ERRORS (PMA-REV 15.0) SLIST L TTY GO SEG (ØØØ1) SEG (0002) RLIT LDA = '456 02.000005 (ØØØ3) STR 000000: STA BUFF1 Ø4.000400L (0004) øøøøø1: LDA STCK 000002: 02.000012S (ØØØ5) STA BUFF2 000003: 04.000401L (0006) 000611 (0007) PRTN 000004: (0008) ***** DATA AREA ***** DYNM STCK(1) 000012 (ØØØ9) (ØØ1Ø) LINK BSS 1 (ØØ11) BUFF1 000400> 1 BSS 000401> (ØØ12) BUFF2 ECB STR 000402> 000000 (ØØ13) ECB1 000014 000011 000000 177400 014000 000422 (0014) END ECBl ØØØØØ5: 00.000456A LINK ØØØØ22 STACK ØØØØ13 TEXT SIZE: PROC 000006 000400L 0004 ØØ11 BUFF1 BUFF2 000401L 0006 ØØ12 ECB1 000402L 0013 ØØ14 000012S 0005 ØØØ9 STCK STR ØØØØØØ øøø3 ØØ13 ØØØØ ERRORS (PMA-REV 15.Ø) OK, SEG GO ``` ``` # DELETE $TTY ``` # LOAD SAVE FILE TREE NAME: \$TTY \$ LOAD B TTY LOAD COMPLETE \$ SAVE \$ MAP \*START 004002 000002 \*STACK 004001 001006 \*SYM 000003 SEG. # TYPE LOW HIGH TOP 004001 PROC## 001000 001005 001005 004002 DATA 000002 000021 000021 ROUTINE ECB PROCEDURE ST. SIZE LINK FR. #### 4002 0000002 4001 001000 000014 000022 4002 177400 DIRECT ENTRY LINKS COMMON BLOCKS OTHER SYMBOLS \$ EXECUTE \*\*\*\* \*\*\*\*\* PROGRAM NOW WORKS. NOTE THAT LOAD MAP \*START ENTRY HAS \*\*\*\* ADDRESS OF SEGMENT 4002 WORD 2, THE LOCATION TO START \*\*\*\*\* EXECUTION. \*\*\*\* OK, # PMA USAGE The Prime Macro Assembler (PMA) is a two pass assembler (three pass in SEG or SEGR mode). The first pass generates a symbol table and identifies external references; the second pass generates object code blocks for input to the loader and, optionally, creates a listing. The three pass assembly in SEG or SEGR mode permits optimization of stack and link frame references. ## INVOKING THE PRIME MACRO ASSEMBLER (PMA) PMA is invoked by the command: ## PMA pathname [-option-1] [-option-2]...[-option-n] where **pathname** is the pathname of the PMA source file and **option-1**, **option-2**, etc. are the mnemonics for one of the options described below. All options must be preceded by a dash "-". For example, the command: PMA ALPHA>BETA -ERRLIST means assemble the file ALPHA located in UFD BETA and list only the errors, while PMA ALPHA means, assemble the file ALPHA located in the home UFD and produce whatever listing the program specifies (see listing pseudo-operations in Section 16 – Pseudo-Operations). The listing name (if any) will be L\_ALPHA. PMA ALPHA -LISTING BETA means, assemble the file ALPHA located in the current UFD, generate a binary file, and produce whatever listing the program specifies. The listing filename will be BETA. | Option | Meaning | |-------------------|-----------------------------------------------------------------------------------------------------------| | -INPUT treename | Input treename | | -LISTING treename | Listing treename | | -BINARY treename | Object file treename | | -EXPLIST | Generates full assembly listing (overrides the pseudo-operation NLIST) and forces listing file generation | | -ERRLIST | Generates errors-only listing, and forces listing file generation | | -XREFL | Generates complete cross reference | | -XREFS | Omits from the listing symbols which have been defined but not used | ## FILE USAGE Three files may be involved during an assembly: | File Type | PRIMOS File unit | |-----------|------------------| | Source | 1 | | Listing | 2 | | Object | 3 | PMA automatically opens files for listing and object output. B\_source-filename is the default object name; L\_source-filename is the default listing name. Use the -BINARY option to charge the object default and -LISTING option to change the listing default. The PRIMOS commands LISTING and BINARY permit you to concatenate files, since they remain open when the assembler returns control to PRIMOS. ## ASSEMBLER MESSAGES When the assembler reads the END statement of the input file on the second pass, it prints a message, terminates assembly, and returns control to PRIMOS command level. The message contains a decimal error count and the version number of the assembler, as in: 0001 ERRORS (PMA-REV 16.2) ## LISTING FORMAT Figure 3-2 shows a section of a typical assembly listing and illustrates the main features. Each page begins with a header and a sequential page number. The first statement in a program is used as the initial page header. If column 1 of any source statement contains an apostrophe ('), columns 10-72 of that statement become the header for all pages that follow, until a new title is specified. User-generated messages may be inserted into the listing output by using the SAY pseudooperation in the source program. Such messages can be used to document the progress of a complex conditional assembly operation. Error listing (bit 2): If this bit is set, only the lines containing errors are listed. Otherwise, listing is controlled by pseudo-operations in the source program. Listing control override (bit 3): If this bit is set, the assembler overrides any listing control pseudo-operations in the source program and lists all statements, including lines within macro expansions and lines that would be skipped by conditional assembly. Otherwise, listing is controlled by pseudo-operations in the source program. Omit unused symbols (bit 4): If this bit is set, symbols which have been defined but not referenced are omitted from the cross-reference. Device options (bits 8-16): The last three octal digits of the A-register select source, listing and object devices respectively. Figure 3-1. A-Register Details ``` (0001) SEG (0002) RLIT 000000: 02.000005 (ØØØ3) STR ='456 LDA 000001: 04.000400L (0004) STA BUFF1 000002: 02.000012S (0005) LDA STCK 000003: 04.000401L (0006) STA BUFF2 000004: 000611 (0007) PRTN (0008) ***** DATA AREA ***** 000012 (0009) DYNM STCK(1) (0010) LINK 000400> (ØØ11) BUFF1 BSS 1 000401> (ØØ12) BUFF2 BSS 1 000402> 000000 (ØØ13) ECB1 ECB STR 000014 000011 000000 177400 014000 000422 (0014) END ECB1 000005: 00.000456A TEXT SIZE: PROC 000006 LINK 000022 STACK ØØØØ13 BUFF1 000400L 0004 0011 BUFF2 000401L 0006 0012 ECB1 000402L 0013 0014 STCK 000012S 0005 0009 STR 000000 0003 0013 0000 ERRORS (PMA-REV 16.2) ``` Figure 3-2. Example of Assembly Listing ## Cross-reference listing (concordance) At the end of the assembly listing appears a cross-reference listing of each symbol's name (in alphabetical order), the symbol's location or address value, and a list of all references to the symbol. The location and address values are in octal unless the PCVH pseudo-operation specifies hexadecimal listing. Each reference is identified by a four-digit line number. The NLST pseudo-operation suppresses the cross-reference listing; the option -XREFS suppresses symbols which have been defined but not used. | PBRK | Program Break. Resume loading at a new location. | |-------------|---------------------------------------------------------------------------| | CH,SS,SY,XP | Symbol control commands. | | EN | ENtire save; saves copy of load session for building of program overlays. | | ER | Controls action taken by loader following errors. | | SZ | Controls use of Sector 0. | ## COMMAND SUMMARY Following is a summary of all LOAD commands, in alphabetical order. All file and directory names may be specified by pathnames, except in the LIBRARY command. All numerical values must be octal. ## ATTACH [pathname] Attaches to specified directory. ## AUTOMATIC base-length Inserts base area of specified length at end of routine if >'300 locations loaded since last base area. ## CHECK [symbol-name] [offset-1]...[offset-9] Checks value of current PBRK against symbol or number. **symbol-name** is a 6 character symbol defined in the symbol table. **offset-1** through **9** are summed to form an address or offset from symbol name. Numbers preceded by "-" are negative. ## **COMMON address** Moves top/starting COMMON location to address. ## DC [END] Defers definition of COMMON block until SAVE command is given. (Low end of COMMON follows top of load.) **END** turns off DC. ## **ENTIRE** pathname Saves entire state of loader as runfile, along with temporary file, for building overlays. ## ERROR n Determines action taken in case of load errors. - n Meaning - SZ errors treated as multiple indirect, others act as n=1. - Display multiple indirects on terminal but continue LOAD; abort load of file for all other errors. - 2 Abort to PRIMOS ## EXECUTE [a] [b] [x] Starts execution with specified register values. Forceloads all modules in specified object file. See LOAD for parameters. ## HARDWARE definition Specifies expected level of instruction execution. | CPU | Definition | |-------------|-----------------------------| | P450 and up | 100 | | P350,P400 | 57 | | P300/FP | 17 FP=Floating Point | | P300 | 3 | | P200/HSA | 1 HSA=High-speed arithmetic | | P100/HSA | 1 | | P200 | 0 | | P100 | 0 | | | | HARDWARE, if given, must precede loading of UII library. ## INITIALIZE [pathname] [parameters] Initializes LOADER and, optionally, does a LOAD. See LOAD for parameters. ## LIBRARY [filename] [loadpoint] Attaches to LIB UFD, loads specified library file (FTNLIB is default), and re-attaches to home directory. ## LOAD [pathname] [parameters] Loads the specified object module. The parameters may be entered in three formats: - 1. loadpoint [setbase-1]...[setbase-8] - 2. \* [setbase-1]...[setbase-9] - 3. symbol [setbase-1]...[setbase-9] In form 1, **loadpoint** is the starting location of the load. In form 2, the load starts at the current PBRK location (\*). In form 3, the load address can be stated symbolically (**symbol**). The remaining numeric parameters (**setbase-1**, etc.) specify the size of linkage areas to be inserted before and after modules during loading. If the last parameter is '177777, the loader requests more setbase values. ## MAP [pathname] [option] Generates load-state map on terminal, or in a file, if pathname is specified. | Option | Meaning | |--------|--------------------------------------------------------------------------------| | 0 | Load state, base area, symbol storage map; symbols sorted by address (default) | | 1 | Load state only | | 2 | Load state and base area | | 3 | Unsatisfied references only | | 4 | Same as 0 | | 5 | System Programmer map | | 6 | Undefined symbols sorted alphabetically | | 7 | All symbols sorted alphabetically | | 10 | Special symbol map for PSD (in a file) | Specifies address resolution mode for next load module (32K Relative, D32R, is default). If used, MODE must precede other LOAD commands. $$P / \left\{ egin{array}{l} FORCELOAD \\ LIBRARY \\ LOAD \end{array} ight\} \left[ pathname \right] \left[ parameters \right]$$ Begins loading at next page boundary. See LOAD for parameters. ## **PAUSE** Leaves loader to execute internal PRIMOS command. Return via START. $$PBRK \left\{ \begin{array}{c} [symbol\text{-name}] \;\; [offset\text{-}1]. \;\; .. [offset\text{-}9] \\ * \;\; offset\text{-}1 \;\; [offset\text{-}2]. \;\; .. [offset\text{-}9] \end{array} \right\}$$ Sets a program break to value of **symbol** plus offset or a number. \* treats sum of numbers as offset from current PBRK. Offsets may be negative. ## **QUIT** Deletes temporary file, closes map file (if loader opened it), and returns to PRIMOS. ## SAVE pathname Writes a memory image of the loaded runfile to the disk. Defines starting location and size of base area. \* is current value of PBRK. ## SS symbol-name Save symbol. Exempts specified symbol from action of XPUNGE. Establishes locations in memory map for common blocks, relocation load points, or to satisfy references. \* is current value of PBRK. Offsets are summed and may be negative. $$\mathbf{SZ} \left\{ egin{array}{l} \mathbf{YES} \\ \mathbf{NO} \end{array} \right\}$$ Permits/prohibits links in sector zero. ## VIRTUALBASE base-start to-sector Copies base sector from **base-start** to corresponding locations in **to-sector**. Used for building RTOS modules. ## XPUNGE dsymbols dbase Deletes COMMON symbols, other defined symbols, and base areas. ## Loading ## Loading R-Mode programs ## INTRODUCTION The PRIMOS LOAD utility converts object modules (such as those generated by PMA) into runfiles that execute in the 32R or 64R addressing modes. (Runfiles to execute in the 64V mode must be loaded using the segmentation utility, SEG.) The following description emphasizes the loader commands and functions that are of most use to the PMA programmer. For a complete description of all loader commands, including those for advanced system-level programming, refer to Reference Guide, LOAD and SEG. ## USING THE LOADER UNDER PRIMOS The PRIMOS command: ## LOAD transfers control to the R-mode loader, which prints a \$ prompt character and awaits a loader subcommand. After executing a command successfully, the loader repeats the \$ prompt character. If an error occurs during an operation, the loader prints an error message, then the \$ prompt charcter. Loader error messges and suggested handling techniques are discussed elsewhere in this section and in Appendix C. Most of the errors encountered are caused by large programs where the user is not making full use of the loader capabilities. When a system error (FILE IN USE, ILLEGAL NAME, NO RIGHT, etc.) is encountered, the loader prints this system error and returns its prompt symbol, \$. The loader remains in control until a QUIT or PAUSE subcommand returns control to PRIMOS, or an EXECUTE subcommand starts execution of the loaded program. Load subcommands can be used in command files, but comment lines result in a CM (command error) message. ## NORMAL LOADING Loading is normally a simple operation with only a few straightforward commands needed. The loader also has many additional features to optimize runfile size or speed, perform difficult loads, and deal with possible complications. The most frequently used load commands and operations are presented first; this enables immediate use of the loader. Advanced features are then described followed by a summary of all loader commands. The following commands (shown in abbreviated form) accomplish most loading functions: PRIMOS-Level commands: **FILMEM** Initializes user space in preparation for load. LOAD Invokes loader for entry of subcommands. RESUME Starts execution of a loaded, SAVEd runfile. LOAD subcommands: MODE option Sets runfile addressing mode as D32R (default) or D64R. LOAD pathname loads specified object file. LIBRARY [filename] Loads library object files from UFD LIB. (Default is FTNLIB.) MAP [option] Prints loadmap. Option 3 shows unresolved refer- ences. INITIALIZE Returns loader to starting condition in case of com- mand errors or faulty load. **SAVE pathname** Saves loaded memory image as runfile. QUIT or PAUSE Return to PRIMOS. Most loads can be accomplished by the following basic procedure: 1. Use the PRIMOS FILMEM command to initialize memory to binary zeroes. Invoke LOAD. 3. Use the MODE command to set the addressing mode, if necessary (The default is 32R mode.) 4. Use loader's LOAD subcommand to load the object file (B\_pathname) and any separately assembled subroutines. 5. Use loader's LIBRARY subcommand to load subroutines called from libraries (the default is FTNLIB in the UFD LIB). Other libraries, such as SRTLIB or APPLIB, must be named explicitly. 6. If you do not have a LOAD COMPLETE, do a MAP 3 to identify the unsatisfied references, and load them. 7. SAVE the runfile under an appropriate name. If these commands produce a LOAD COMPLETE message, then loading was accomplished. If there is a problem, it will become apparent by the absence of a LOAD COMPLETE message or by some other loader error message. (See Appendix C for a complete list of all loader error messages and their probable cause and correction.) After a successful load, start runfile execution from LOAD command level, or quit from the loader and start execution through the PRIMOS RESUME command. An example of such a load is: OK, LOAD GO \$ MO D64R \$ DC \$ LO B ARRAY \$ LI ## Order of loading The following loading order is recommended: 1. Main program. 2. Separately assembled user-generated subroutines (preferably in order of frequency of use). - 3. Other Prime libraries (LI filename). - 4. Standard FORTRAN library (LI). ## Loading library subroutines Standard FORTRAN mathematical and input/output functions are implemented by subroutines in the library file FTNLIB in the LIB UFD. The appropriate subroutines from the file are loaded by the LIBRARY command given without a filename argument. If subroutines from other libraries are used, such as MATHLB, SRTLIB, or APPLIB, additional LIBRARY commands are required which include the desired library as an argument. ## LOAD MAPS During loading the loader collects information about the results of the load process, which can be printed at the terminal (or written to a file) by the MAP command: ## MAP [pathname] [option] The information in the map can be consulted to diagnose problems in loading, or to optimize placement of modules, linkage areas and COMMON in complex loads. Load information is printed in four sections, as shown in Figure 4-1. The amount of information printed is controlled by MAP option codes such as: | Option | Load Map Information | |--------------|----------------------------------------------------------------------| | None, 0 or 4 | Load state, base area, and symbol storage; symbols sorted by address | | 1 | Load state only | | 2 | Load state and base areas | | 3 | Unsatisfied references only | | 6 | Undefined symbols, sorted in alphabetical order | | 7 | All symbols, sorted in alphabetic order | ## Load state The load state area shows where the program has been loaded, the start-of-execution location, the area occupied by COMMON, the size of the symbol table, and the UII status. All locations are octal numbers. - \*START: The location at which execution of the loaded program will begin. The default is '1000. - \*LOW: The lowest memory image location occupied by the program. Executable code normally starts at '1000, but sector 0 address links (if any) begin at '200. - \*HIGH: The highest memory image location occupied by the program (excluding any area reserved for COMMON). - \*PBRK: "Program Break": The next available location for loading. It normally is the location following the last loaded module, but can be moved by PBRK or the LOAD family of commands. - \*CMLOW: The low end of COMMON. - \*CMHGH: The top of COMMON. - \*SYM: The number of symbols in the loader's symbol table. This is usually of not concern unless the symbol space crowds out the last remaining runfile buffer area. (There is room for about 4000 symbols before this is a risk.) \*UII: A code representing the hardware required to execute the instructions in loaded modules. Codes and other information are described later in this section. ### Base areas The base area map includes the lowest, highest and next available locations for all defined base areas. Each line contains four addresses as follows: | *BASE | XXXXXX | YYYYYY | ZZZZZZ | wwwww | |--------|-----------------|----------------|-----------------|----------------------| | XXXXXX | Low | est location d | lefined for thi | s area | | YYYYYY | | | | ng up from XXXXXX | | ZZZZZZ | Nex | t available lo | cation if start | ing down from WWWWWW | | wwwww | / <b>W</b> High | est location | defined for th | is area | ### Symbol storage The symbol storage listing consists of every defined label or external reference name printed four per line in the following format: ### namexx NNNNNN or ### \*\*namexx NNNNNN **NNNNNN** is a six-digit octal address. The \*\* flag means the reference is unsatisfied (i.e., has not been loaded). Symbols are listed by ascending address (default) or in alphabetical order (MA 6 or MA 7). The list may be restricted to unsatisfied references only (MA 3 or MA 6). ### **COMMON blocks** The low end and size of each COMMON area are listed, along with the name (if any). Every map includes a reference to the special COMMON block LIST, defined as starting at location 1. ### LOADER CONCEPTS When standard loading goes well, the user can ignore most of the loader's advanced features. However, situations can arise where some detailed knowledge of the loader's tasks, can optimize size or performance of a runfile, or even make a critical load possible. From that viewpoint, the main tasks of the loader are: - Convert block-format object code into a run-time version of the program (executable machine instructions, binary data and data blocks). - Resolve address linkages (translate symbolic names of variables, subroutine entry points, data items etc. into appropriate binary address values). - Perform address resolution (discussed later). - Detect and flag errors such as unresolved external references, memory overflow, - Build (and, on request, print) a load map. The map may also be written to a file. - Reserve COMMON areas as specified by object modules. - Keep track of runfile's hardware execution requirements and make user aware of need to load subroutines from UII library. ### Virtual loading The loader occupies the upper 32K words of the user's 64K-word virtual address space. Programs up to 32K words are loaded directly into the memory locations from which they execute. Programs loaded in this manner can be started by the loader's EXECUTE command without being saved. For larger 64R-mode programs, the loader uses the available memory as buffer space and transfers loaded pages of memory to a temporary file that accomodates a full 64K-word memory image. When loading is complete, the file must be assigned a name by the loader's SAVE command; it can then be executed either through the loader's EXECUTE command or the PRIMOS RESUME command. The loader remains attached to the working directory throughout loading, for access to the temporary file. Files in other directories can be loaded by giving a pathname in a LOAD command. ### Use of pathnames Pathnames can be used to specify object files in all commands except LIBRARY, which accepts only a simple filename of a file within the LIB UFD. ### Object code Inputs to the loader are in the form of object code—a symbolic, block-format file generated by all of Prime's language translators. Prime's standard library files consist of subroutines in this format. The loader combines the user's main program object file with the object files of all referenced subroutines (either those in the library, or those generated and separately compiled by the user) into a single runfile. The runfile is then ready for execution, either directly through the loader's EXECUTE command or through the PRIMOS RESUME command. ### Runfiles A runfile consists of a header block followed by the runfile text in memory image format. The header contains information that enables the runfile to be brought into memory by the PRIMOS RESTORE or RESUME command. Contents of the header can be examined after a RESTORE by the PM command. (See PRIMOS Commands Reference Guide.) ### Selecting the addressing mode The 32R addressing mode is retained as the loader's default for compatibility with existing command files. The only significant difference between 32R and 64R for small programs is that 32R permits multiple indirect links, while 64R ellows only one level of indirection. In certain situations such as processing of multi-dimensional arrays, 32R mode may enable the programmer to write a program that is somewhat more compact or runs slightly faster. However, for programs that approach the 32K word boundary, 64R mode ensures successful loading with no significant penalties of size or speed. Thus MODE D64R is recommended for most applications. ### Base areas "Base Area" is discussed in Section 10—Memory Reference Concepts. When one of the messages is printed: BASE SECTOR 0 FULL symbolname XXXXXX NEED SECTOR 0 LINK This condition, usually encountered only when loading large programs, can be avoided in several ways: - Give the AUTOMATIC command to enable the loader to assign local linkage areas before and after individual subroutines. - Use setbase parameters with a LOAD or LIBRARY command to insert local linkage areas where they are needed. - Use the SETBASE command to designate a base areas where it is required. - During assembly, use the SETB pseudo-operation. ### **UII** handling The loader can keep track of the CPU hardware required to execute the instructions generated by the modules already loaded. This is shown in the UII entry in the load state section of a load map. The codes are: | UII Value | CPU Required | |-----------|------------------------------------| | 100 | Prime 450 and up | | 57 | Prime 350 or 400 | | 17 | Prime 300 with FP Hardware | | 3 | Prime 300 | | 1 | Prime 100 with HSA or 200 with HSA | | 0 | Prime 100 or 200 | If the UII code on the load map is greater than the value for the target CPU, then it will be necessary to load part of the UII library to make execution possible. When a CPU encounters an instruction not implemented by hardware, a UII (Unimplemented Instruction Interrupt) occurs and control is transferred to the appropriate UII routine. This routine simulates the missing hardware with software routines. However, the UII routine must be loaded by the command LI UII, which should be the last LOAD command before the program is saved. The appropriate routines will be selected from this library to satisfy the additional hardware requirements of the program. To make sure that only the required subroutines are loaded, the user can "subtract" hardware features that are present in the CPU by entering a HARDWARE command. For example, assume: - A load session produces a load map UII value of 57. - The target CPU is a Prime 300 with floating point (UII value 17). The command: ### HA 17 reduces the load state UII value to 40 (i.e., '57-'17) and ensures that the floating point subroutines do not occupy space in the runfile. If, after a HARDWARE command, the load state UII value is 0, the UII library need not be loaded. ### System programming features The following commands are primarily of interest to systems programmers. They are described in more detail in the Reference Guide, LOAD and SEG: | F/ | Prefix to LOAD and LIBRARY which forceloads unreferenced modules. | |----|--------------------------------------------------------------------------------------------------| | P/ | Prefix to LOAD and LIBRARY which starts loading on next page boundary. (Can reduce paging time.) | | *START *CMLOW | ØØ1ØØØ<br>Ø77777 | *LOW<br>*CMH | | ØØ2ØØ<br>77777 | *HIGH<br>*SYM | ØØ7775<br>ØØØØ7Ø | *PBRK<br>*UII | 106376<br>000001 | |----------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------------------------------------------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------------------------------------------------------------------------------------------------|------------------| | *BASE | 000200 | ØØØ225 | ØØØ | 777 ØØI | <b>0777</b> | | | | | *BASE | 001534 | 001600 | 001 | | 16Ø5 | | | | | *BASE | ØØ2576 | 002660 | 002 | | 2661 | | | | | *BASE | ØØ3624 | ØØ3663 | 003 | 665 ØØ3 | 3665 | | | | | *BASE | 004664 | 004706 | 004 | 707 004 | 4707 | | | | | **GHOST | ØØ1 Ø2 | | | ØØ1Ø31 | F\$WX | ØØ1Ø37 | F\$10 | 001113 | | F\$A1 | 00160 | _ • | | 001606 | F\$A5 | ØØ1613 | F\$A2 | 001621 | | F\$A6 | ØØ162 | | | 001645 | F\$CB | ØØ2326 | F\$IOBE | | | WRASC<br>LUTBL | ØØ55Ø<br>ØØ564 | | CS\$.<br>IBL | ØØ5514<br>ØØ57Ø1 | IOCS\$T<br>RSTBL | 005613<br>005736 | WATBL<br>O\$ADØ7 | 005625<br>005773 | | O\$ADØ8 | | | AAØl | 005701 | PRSPE\$ | | OERRTS | | | ERRPR\$ | | | vF\$\$ | 007436 | WTLIN\$ | | ERRSET | | | F\$ER | 00744 | 7 F\$ | IT | 007454 | EXIT | ØØ7534 | ACl | ØØ7537 | | AC2 | 00754 | | | ØØ7541 | AC4 | 007542 | AC5 | 007543 | | TNOU | ØØ754 | | | 007634 | T10U | 007641 | TIIB | 007661 | | T10B<br>SCHAR | ØØ766<br>ØØ775! | - • | 11 | 007673 | F\$AT1 | ØØ7675 | GCHAR | 007740 | | COMMON B | LOCKS | | | | | | | | | | | | | | | | | | | LIST | 00000 | 1 | | | 007776 | 076400 | | | | LIST | ØØØØØ. | 1 | | A. Full | øø7776<br>Map [MAP | | | | | LIST | *start ( | 901 000 | *LOW | 000200 | Map MAP *HIGH 007 | 7775 *PBRI | | | | LIST | *START (<br>*CMLOW ( | 001 000<br>377777 | *LOW<br>*CMHGH | 000200<br>077777 | *HIGH 007<br>*SYM 000 | ] | ( 106376<br>000001 | | | LIST | *START 0 | 001000<br>077777<br>000200 00<br>001534 00 | *LOW<br>*CMHGH<br>0225 0 | 000200<br>077777<br>00777 000<br>01605 00 | Map MAP *HIGH 007 | 7775 *PBRI | | | | LIST | *START 6 *CMLOW 6 *BASE 6 *BASE 6 *BASE 6 | 001000<br>077777<br>000200 00<br>001534 00<br>002576 00 | *LOW *CMHGH Ø225 01 1600 02 2660 0 | 000200<br>077777<br>000777 00:<br>01605 00:<br>02661 00: | Map MAP *HIGH 007 *SYM 000 | 7775 *PBRI | | | | LIST | *START (2 *CMLOW 2 *BASE (2 *B)))))))))))))))))))))))))))) | 201000<br>2077777<br>2002200 00<br>201534 00<br>202575 00<br>202575 00<br>203624 00<br>204664 00<br>207537<br>207543<br>201605 | *LOW *CMHGH 0225 0 1500 0 2660 0 3663 0 4706 0 AC2 ERRPR F\$A2 | 0000200<br>077777<br>000777 001<br>01605 001<br>02661 001<br>03665 001<br>04707 004<br>007540<br>\$ 007433<br>001621 | *HIGH 007 *SYM 000 0777 1605 2661 3665 4707 AC3 0 ERRSET 0 F\$A3 0 | 7775 *PBRF<br>7775 *UII<br>7070 *UII<br>707541 AC4<br>707541 AC4<br>707606 F\$A | 000001<br>007542<br>T 007534<br>5 001613 | | | LIST | *START 0 *CMLOW 0 *BASE 0 *BASE 0 *BASE 0 *BASE 0 AC1 AC5 F\$A1 F\$A6 F\$CB | 001000<br>077777<br>000200 00<br>001534 00<br>002575 00<br>003624 00<br>004664 00<br>007537<br>007543<br>001605<br>001627<br>002326 | *LOW *CMHGH 0225 @ 1600 @ 2660 @ 3663 @ 4706 @ AC2 ERRPR | 0000200<br>077777<br>000777 000<br>01605 000<br>02661 000<br>03665 000<br>04707 000<br>007540<br>\$ 007433 | *HIGH 007 *SYM 000 0777 1005 2661 AC3 0 ERRSET 0 F\$A3 0 F\$AT 0 | 7775 *PBRF<br>7070 *UII<br>007541 AC4 | 000001 0007542 007534 001613 007675 | | | LIST | *START 0 *CMLOW 0 *BASE 0 *BASE 0 *BASE 0 *BASE 0 AC1 AC5 F\$A1 F\$A6 F\$CB F\$IOBF | 001000<br>077777<br>000200 00<br>001534 00<br>002576 00<br>004664 00<br>007537<br>007543<br>001605<br>001627<br>002405 | *LOW *CMHGH 0225 0 1500 0 2660 0 3663 0 4706 0 AC2 ERRPR FSA2 FSA2 FSA7 FSER FSWA | 0007200<br>077777<br>00777 003<br>01605 003<br>02661 003<br>04707 004<br>007540<br>\$ 007433<br>001621<br>001645<br>007447<br>001031 | *HIGH 007 *SYM 000 3777 1605 2561 AC3 0 ERRSET 0 FSA3 0 FSAT 0 FSWX 0 | 7775 *PBRF<br>7775 *UII<br>70770 *UII<br>707541 AC4<br>707444 EXI<br>701606 FSA<br>707673 FSA<br>707454 FSI<br>701037 GCF | 000001 0007542 T 007534 5 001613 T1 007675 O 001113 AR 007740 | | | LIST | *START 0 *CMLOW 0 *BASE 0 *BASE 0 *BASE 0 *BASE 0 AC1 AC5 F\$A1 F\$A6 F\$CB F\$IOBF **CHOST O\$AA01 | 001000<br>077777<br>000200 00<br>001534 00<br>002575 00<br>002575 00<br>004664 00<br>007537<br>001605<br>001627<br>002326<br>005405<br>001625<br>005405<br>001625<br>006200 | *LOW *CMHGH 0225 | 0000200<br>077777<br>000777 000<br>01605 000<br>02661 000<br>04707 000<br>007540<br>\$ 007433<br>001621<br>001645<br>007447<br>001031<br>0016514<br>7 005773 | *HIGH 007 *SYM 000 0777 1605 2661 3665 4707 AC3 0 ERRSET 0 FSAT 0 FSHT 0 FSHT 0 FSHT 0 OSAD08 0 | 7775 *PBRF<br>7775 *UII<br>7775 *UII<br>70770 *UII<br>707444 EXI<br>701606 FSA<br>707673 FSA<br>707673 FSA<br>707673 GCH<br>7085613 LUI<br>706136 OEF | 000001 007542 T 007534 5 001613 T1 007675 O 001113 AR 007740 BL 005644 RT\$ 006427 | | | LIST | *START ( *CMLOW ( ) *BASE ( ) *BASE ( ) *BASE ( ) *BASE ( ) *BASE ( ) *BASE ( ) *CS ( ) *SAG ( ) *SCB ( ) *SCB ( ) *SCB ( ) *SGHOST ( ) *CMLOW | 001000<br>077777<br>000200 00<br>001534 00<br>002575 00<br>004664 00<br>007537<br>007543<br>001606<br>001627<br>002326<br>005405<br>001025 | *LOW *CMHGH 0225 0 1600 0 2660 0 3663 0 4706 0 AC2 ERRPR F\$A2 F\$A7 F\$ER F\$WA IOCS\$ | 0000200<br>077777<br>000777 000<br>01605 000<br>02661 000<br>04707 000<br>007540<br>\$ 007433<br>001621<br>001645<br>007447<br>001031<br>0016514<br>7 005773 | *HIGH 007 *SYM 000 0777 1005 2661 AC3 0 ERRSET 0 FSA3 0 FSAT 0 FSWX 0 IOCSST 0 SAD08 0 PUTBL 0 | 7775 *PBRF<br>7775 *UII<br>7775 *UII | 000001 0007542 007534 001613 007675 001113 AR 007760 BL 005644 RT\$ 006427 BL 005736 | | | LIST | *START 0 *CMLOW 0 *BASE *BAS | 001000<br>077777<br>000200 00<br>001534 00<br>002576 00<br>007537<br>007543<br>001606<br>001627<br>002326<br>005405<br>001025<br>001025<br>006235 | *LOW *CMHGH 0225 0 1600 0 2660 0 3663 0 4706 0 AC2 ERRPR F\$A7 F\$ER F\$WA IOCS\$ OSAD0 PRWF\$ | 0000200<br>077777<br>000777 000<br>01605 00<br>02661 000<br>04707 000<br>007514<br>001621<br>001645<br>007443<br>001645<br>007447<br>001031<br>005514<br>7 005573<br>8 007436 | *HIGH 007 *SYM 000 3777 1005 2661 AC3 0 ERRSET 0 FSA3 0 FSAT 0 FSA7 0 FSA7 0 FSA7 0 FSA8 0 FSA8 0 FSA8 0 FSA8 0 FSA9 | 7775 *PBRF<br>7775 *UII<br>7775 *UII<br>70770 *UII<br>707444 EXI<br>701606 FSA<br>707673 FSA<br>707673 FSA<br>707673 GCH<br>7085613 LUI<br>706136 OEF | 000001 0007542 T 007534 5 001613 T1 007675 O 001113 AR 007740 BL 005644 RT\$ 006427 BL 005736 U 007641 | | Figure 4-1. Examples of load maps # Loading segmented programs ### INTRODUCTION The PRIMOS SEG utility converts object modules (such as those generated by the PMA) into segmented runfiles that execute in either 64V or 32I addressing mode and take full advantage of the architecture and instruction set of the Prime 350 and up. Segmented runfiles offer the following advantages: - Much larger programs: up to 256 segments per user program (32 Megabytes). - Access to V-mode and I-mode instructions and architecture (Prime 350 and up) for faster execution. - Ability to install shared code: single copy of a procedure can service many users, significantly reducing paging time. - Reentrant procedures permitted: procedure and data segments can be kept separate. The following description emphasizes the commands and functions that are of most use to the PMA programmer. For a complete description of all SEG commands, including those for advanced system-level programming, refer to the Reference Guide, LOAD and SEG. ### USING SEG UNDER PRIMOS SEG is invoked by PRIMOS command: ### SEG [pathname] A **pathname** is given only when an existing SEG runfile is to be executed. Otherwise, the command transfers control to SEG command level, which prints a "#" prompt character and awaits a subcommand. After executing a subcommand successfully, the loader repeats the prompt character. SEG employs two subprocessors, LOAD and MODIFY, which accept further subcommands. The subprocessors use the "\$" prompt character. If an error occurs during an operation, SEG prints an error message, then the prompt character. Error messages and suggested handling techniques are discussed elsewhere in this section and in Appendix C. When a system error (FILE IN USE, ILLEGAL NAME, NO RIGHT, etc.) is encountered, SEG prints the system error and returns the prompt symbol. SEG remains in control until a QUIT subcommand returns control to PRIMOS, or an EXECUTE subcommand starts execution of the loaded program. SEG subcommands can be used in command files, but comment lines are accepted only within the LOAD subprocessor. ### NORMAL LOADING Loading is normally a simple operation with only a few straightforward commands needed. SEG also has many additional features to optimize runfile size or speed, perform difficult loads, load for shared procedures, and deal with possible complications. To facilitate immediate use of SEG, the most frequently used commands and operations are described first. Advanced features are then described, followed by a summary of all SEG commands. The following commands (shown in abbreviated form) accomplish most loading functions: SEG-Level commands: **DELETE** Deletes segmented runfile. **HELP** Prints a list of SEG commands at terminal. LOAD Invokes loader subprocessor for entry of subcom- mands. LOAD subcommands: **LOAD pathname** Loads specified object file. LIBRARY [filename] Loads library object files from UFD LIB. (Default is PFTNLIB and IFTNLB, in that order.) MAP [option] Prints loadmap. Option 3 shows unresolved refer- ences. INITIALIZE Returns loader to starting condition in case of com- mand errors or faulty load. **SAVE** Saves loaded memory image as runfile. **RETURN** Returns to SEG command level. **QUIT** Return to PRIMOS. Most loads can be accomplished by the following basic procedure: - Invoke SEG from PRIMOS level. - Enter the LOAD command to start the LOAD subprocessor (\$ prompt) - Use the load subprocessor's LOAD subcommand to load the object file (B\_ filename) and any separately assembled subroutines. - Use load subprocessor's LIBRARY subcommand to load subroutines called from libraries (the default is PFTNLB and IFTNLB in the UFD LIB). Other libraries, such as VSRTLB or VAPPLB, must be named explicitly. - If you do not have a LOAD COMPLETE, do a MAP 3 to identify the unsatisfied references, and load them. - SAVE the runfile. If these commands produce a LOAD COMPLETE message, then loading was accomplished. If there is a problem, it will become apparent by the absence of a LOAD COMPLETE message or some other SEG error message. (See Appendix C for a complete list of all SEG error messages and their probable cause and correction.) After a successful load, start runfile execution from loader command level, or quit from the loader and start execution through the PRIMOS RESUME command. An example of such a load is: ``` OK, SEG GO # LOAD SAVE FILE TREE NAME: #ARRAY $ LO B_ARRAY $ LI $ SA $ MA M_ARRAY $ OU ``` ### Order of loading The following loading order is recommended: - 1. Main program. - 2. Separately assembled user-generated subroutines (preferably in order of frequency of use). - 3. Other Prime Libraries (LI filename). - 4. Standard FORTRAN library (LI). ### Loading library subroutines Standard FORTRAN mathematical and input/output functions are implemented by subroutines in the library file FTNLIB in the LIB UFD. The appropriate subroutines from this file are loaded by the LIBRARY command given without a filename argument. If subroutines from other libraries are used, such as VSRTLB or VAPPLB, additional LIBRARY commands are required which include the desired library as an argument. ### LOAD MAPS During loading, SEG collects (and stores, as part of the segmented runfile) information about the results of the load process. This can be printed at the terminal (or written to a file) by the load subprocessor's MAP command: ### MAP [pathname] [option] The information in the map can be consulted to diagnose problems in loading, or to optimize placement of modules, linkage areas and COMMON in complex loads. If a file **pathname** is given, the map is written to a file instead of being printed at the terminal. The loadmap is particularly useful for: - Location where program halted (Link Base (LB) address after a crash). - Modules not loaded (MA 3 or MA 6). - Reason for stack overflow (Stack Base (SB) address after a crash). When a map file is specified, it is opened on PRIMOS Unit 13 and remains open until the load session is completed. Any additional MAP commands specifying output to a file will use the one already opened; exiting from the Loader (via EXECUTE, QUIT, or RETURN) closes the map file. If the user has opened a file on PRIMOS Unit 13 prior to invoking SEG's loader, then this file will be used for the map. In this case, leaving the Loader does not close the file. The full SEG load map consists of seven sections, not all of which may be present in any load. (See Figure 5-1) In particular, Section III may not be present in small SEG loads. The amount of information printed is controlled by MAP option codes: | Option | Load Map Information | |-----------------|--------------------------------------------------------------------------------------------------------------------------------------------| | None,<br>0 or 4 | Extent, segment assignments, base areas, symbol storage (symbols sorted by address), direct entry links, common blocks, and other symbols. | | 1 | Extent and segment assignments only | | 2 | Extent, segment assignments and base areas | | 3 | Undefined symbols, sorted by address | | 6 | Undefined symbols, sorted alphabetically | | 7 | Full map, symbols, sorted in alphabetic order | | 10 | Symbols, sorted by ascending address | | 11 | Symbols, sorted alphabetically | | | | ### Section I-Extent The extent area shows where the program has been loaded, the start-of-execution location, and the size of the symbol table. All locations are octal numbers. \*START: The segment number and word location for the start-of-execution. At the beginning of a load, the start address is initialized to 000000 000000. SEG fills in \*START for the first segmented procedure encountered (usually the main program). \*STACK: Segment number and word location of the start of the stack; initialized to 177777 000000 at the start of a load. This value is not changed until a loader SAVE or EXECUTE command is invoked. The default stack is in the first procedure segment with 6000 (octal) free locations at the top of memory. \*SYM: Address of the bottom of the symbol table (one word only as it is a 64R mode address). Indicates to the user how much space is left for the symbol table. To determine the location of the top of the symbol table, generate a map prior to loading; the top and bottom of the symbol table will be identical and \*SYM will also be the location of the top. ### Section II—Segment assignments Each segment is labeled as procedure (PROC) or data (DATA); the segment chosen for the stack is identified by ## following the segment type. The list is sorted in order of segment assignment. **LOW:** Lowest loaded location in the segment. (Not necessarily the lowest assigned location.) Initialized to '177777 (-1) at segment creation; if the segment is used only for uninitialized COMMON areas, LOW is not changed. **HIGH:** Highest loaded location in the segment. (Not necessarily the highest assigned location.) Initialized to '000000 at segment creation; if the segment is used only for uninitialized COMMON areas, HIGH is not changed. | *START | 004002 | ØØØØØ3 | *STACK | 00400 | ו מו | 1720 | *SYM | 000146 | | | |------------------|---------------|----------|-------------|----------|--------------|----------------|------------|------------|-------|---------| | | | | | | | | "5 IM | 46 1 0 0 0 | | | | SEG. #<br>Ø04001 | TYPE<br>PROC# | | OW<br>1 a a | HIGH | | OP | | | | | | 004001 | | | | 011723 | | .1717 | | | | | | 00400Z | DATA | ששש | 001 1 | 100462 | ΤK | 80553 | | | | | | *BASE | 004001 | 000100 | 000177 | ØØØ77 | 7 Ø0 | 0777 | | | | | | ROUTINE | | ECB | PRY | CEDURE | q | T. SIZ | F ITNE | KFR. | | | | #### | 4002 | 000003 | 4001 | 00100 | | 000012 | | | 17740 | 101 | | F\$WB | 4001 | 005371 | 4001 | 00106 | | 000060 | | | Ø76Ø3 | | | F\$RB | 4001 | 005331 | 4001 | 001072 | | 000060 | | | Ø76Ø3 | | | F\$DE | 4001 | 005411 | 4001 | 001100 | | 000060 | | | Ø76Ø3 | | | F\$EN | 4001 | 005431 | 4001 | 001103 | | 000050 | | | Ø76Ø3 | | | F\$WA | 4001 | 005351 | 4001 | 00112 | | 000060 | | | Ø76Ø3 | | | F\$RA | 4001 | 005311 | 4001 | 001126 | | 000060 | | | 07603 | | | F\$Al | 4001 | 005451 | 4001 | 001520 | 9 | 000060 | 00010 | 7 4002 | ø76ø3 | 5 | | F\$A2 | 4001 | 005471 | 4001 | 00152 | 3 | 000060 | | | Ø76Ø3 | | | F\$A5 | 4001 | 005511 | 4001 | 001526 | 5 | 000060 | | | Ø76Ø3 | | | F\$A6 | 4001 | 005531 | 4001 | ØØ1533 | 3 | 000060 | 00010 | 7 4002 | 07603 | | | F\$A7 | 4001 | 005551 | 4001 | 001536 | | 000060 | | | 07603 | | | F\$CB | 4001 | 005571 | 4001 | ØØ2236 | ð . | 000060 | | | 07603 | 5 | | RDASC | 4001 | ØØ5736 | 4001 | 00561 | L | 000026 | | | 07634 | | | RDBIN | 4001 | 005756 | 4001 | ØØ5656 | 5 | 000026 | | | Ø7634 | | | WRASC | 4001 | ØØ5776 | 4001 | 005676 | | 000026 | 00000 | 6 4002 | Ø7634 | | | WRBIN | 4001 | 006016 | 4001 | 00571 | 5 | 000026 | 00000 | 16 4002 | 07634 | 4 | | IOCS\$ | 4001 | 006136 | 4001 | 006044 | 1 | 000040 | 00000 | 4 4002 | Ø7635 | 2 | | IOCS\$T | 4001 | 006707 | 4001 | 006174 | 1 | ØØØØ1Ø | 00015 | 2 4002 | Ø7635 | 6 | | ATTDEV | 4001 | 006727 | 4001 | 006250 | | 000014 | 00015 | 2 4002 | Ø7635 | 6 | | IOC\$RA | 4001 | 006747 | 4001 | 006313 | | 000006 | | 2 4002 | Ø7635 | | | I\$BDØ7 | 4001 | 007117 | 4001 | 007004 | | 000036 | 00000 | 2 4002 | Ø7653 | | | O\$BDØ7 | 4001 | 007236 | 4001 | 007142 | | 000034 | | | Ø7653 | 2 | | O\$ADØ8 | 4001 | ØØ735Ø | 4001 | 007261 | | 000034 | | | Ø7653 | 4 | | I\$AA12 | 4001 | 007616 | 4001 | 007373 | | 000052 | 00001 | 3 4002 | Ø7653 | 6 | | O\$AAØ1 | 4001 | ØØ77Ø1 | 4001 | ØØ7652 | 2 | 000030 | | | Ø7655 | 1 | | F\$IOER | 4001 | 007752 | 4001 | ØØ7722 | 2, | 000014 | 00000 | 6 4002 | Ø7655 | 3 | | I\$ADØ7 | 4002 | Ø7717Ø | 4001 | 010015 | 5 | 000030 | 00005 | 6 4002 | Ø7656 | 1 | | O\$ADØ7 | 4002 | Ø77246 | 4001 | Ø1 Ø1 31 | | 000030 | 00005 | 6 4002 | Ø7663 | 7 | | PRWFIL | 4002 | Ø77323 | 4001 | 010245 | 5 | 000046 | 00005 | 5 4002 | Ø7671 | 5 | | PRSPE\$ | 4002 | Ø77377 | 4001 | Ø1 Ø444 | 1 | 000044 | 00005 | 4 4002 | Ø7677 | 2 | | SEARCH | 4002 | Ø7746Ø | 4001 | 010605 | | 000034 | 00012 | | 07704 | | | OERRT\$ | 4002 | Ø77574 | 4001 | 011014 | | 000052 | 00066 | | Ø7716 | | | F\$ERX | 4001 | 011200 | 4001 | 011154 | | 000020 | 00000 | | 10005 | 1 | | TONL | 4001 | 011230 | 4001 | Ø11221 | | 000012 | 00000 | | 10005 | | | GCHAR | 4001 | Ø11251 | 4001 | Ø11271 | | ØØØØ2Ø | 00000 | 0 4002 | 10006 | 1 | | SCHAR | 4001 | 011310 | 4001 | Ø11330 | | 000024 | 00000 | 0 4002 | 10006 | 1 | | TlOB | 4001 | Ø11374 | 4001 | Ø11355 | | ØØØØ46 | | | 10006 | | | GETERR | 4001 | Ø1146Ø | 4001 | 011415 | | 000040 | | | 10006 | | | ERRSET | 4001 | Ø11631 | 4001 | Ø115Ø0 | J | ØØØØ34 | 00007 | 1 4002 | 10006 | 3 | | DIRECT E | NTRY LIN | NKS | | | | | | | | | | CNIN\$ | 400 | L Ø1165: | | L\$\$ | 4001 | Ø1169 | 56 E | RRPR\$ | 4001 | Ø11662 | | EXIT | 4001 | 01166 | 5 PRW | if\$\$ | 4001 | | | DLIN\$ | 4001 | Ø11675 | | SRCH\$\$ | | | | U | 4001 | Ø1170 | 05 T | NOUA | 4001 | 011710 | | WTLIN\$ | 4001 | Ø1171 | 1 | | | | | | | | | COMMON B | LOCKS<br>4002 | 2 ØØØØ35 | 5 Ø764Ø | ıø | | | | | | | | OTHER CL | | | | | | | | | | | | OTHER SYN | | 005151 | **~= | CTT | <u> </u> | ggggg | ) )<br>) ) | \$TORE | 1000 | 076E 11 | | PUTBL | 4001<br>4002 | | | | 4002<br>4002 | 00003<br>07704 | | \$IOBF | 4002 | Ø76544 | | | 1002 | . 5.,512 | | | | 2 | | | | | | | | | | | | | | | | | 1 March, 1979 5-5 FDR 3059 **TOP:** Highest assigned location in the segment. Top should not be lower than HIGH. If it is, the user may have specified incorrect load addresses. When not using default values, the user is responsible for loading into correct areas. TOP is initialized to '177777 (-1) at segment creation. When space is reserved for large COMMON blocks, the loader will only set TOP to a maximum of '177776 even though the entire segment to '177777 is reserved. The reason for this is: a LOW, HIGH, and TOP of 177777 000000 177777 labels an empty segment. ### Section III—Base areas | *BASE | VVVVVV | wwwww | XXXXX | YYYYYY | ZZZZZZ | |--------|--------|------------------|----------------|--------------|------------------| | vvvvv | Segn | nent number | | | | | wwwww | W Lowe | est location for | base area | | | | XXXXXX | | t available loca | | | | | YYYYYY | Next | t available loca | tion if starti | ng down from | highest location | | ZZZZZZ | High | est location for | base area | | | The lowest default location for the sector zero base area is '100. There may be a sector zero base area in each procedure segment; there must be none in data segments. Base areas other than sector zero ones may be generated by PMA modules. ### Section IV—Symbols A main program or subroutine compiled in 64V or 32I mode is called a procedure. For a complete discussion, see Sections 9 and 10 in this manual; also the Reference Guide, System Architecture. A procedure is composed of a procedure frame (the executable code), an ECB (the entry control block which points to the procedure frame), a link frame (static storage, constants, transfer vectors) and a stack frame (dynamically allocated storage which is assigned when the routine is called and released upon return from the routine). This section of the map describes these items. The ECB is normally part of the link frame although the programmer may place it in the procedure frame. The procedure frame will be located in a segment reserved for procedure frames. Link frames and COMMON blocks will be located in segments reserved for data. The first pair of numbers in this section of the map is the segment and word address for the ECB; the second pair is the segment and word address for the procedure. **ST. SIZE:** is the size of the stack frame (working area) created whenever the routine is called. Its segment (and location therein) are assigned at execution time. LINK FR: is the size of the link frame. The last two columns are the link frame segment and offset. Note that the offset is '400 locations lower than the actual position, for compatibility with the information printed by the PRIMOS PM command. The segment number is usually that for the ECB. Procedures with no names, specifically a main program, are identified by #### in the name field. ### Section V-Direct entry links PRIMOS supports direct entry calls to the supervisor for certain routines. These are created as fault pointers in the SEG runfile. Where references are satisfied by these fault pointers, they will appear in the DIRECT ENTRY LINKS section of the map. ### Section VI—COMMON blocks Lists each COMMON block, its segment number, starting word address in the segment, and size. ### Section VII—Other symbols (including undefined symbols) Lists the symbol, its segment, and word address in that segment. As in Section VI, the format is three symbols per line. Unsatisfied references are preceded by \*\* The numbers for unsatisfied references (segment and word address) locate the last request for the routine processed by the loader. This allows the routines calling missing routines to be identified. ### ADVANCED SEG FEATURES When standard loading goes well, the user can ignore most of the SEG's advanced features. However, situations can arise where some detailed knowledge of SEG and segmented runfile organization can optimize size or performance of a runfile, or even make a critical load possible. The following topics are particularly valuable. ### Segment usage A segment is a 64K word block of user's virtual address space. Segment '4000 is the segment that SEG and other external commands occupy when invoked. Segment '4000 is the lowest-valued non-shared segment in the PRIMOS system. SEG creates a runfile of up to 256 segments. PRIMOS assigns memory segments to a user as they are accessed. These are not re-assigned until logout. Since only a fixed number of segments are available for all users, extra segments should not be invoked unless the user is actually executing or examining a segmented program. Most of the functions of SEG use only one segment; only those options which restore a runfile use extra segments, i.e., RESTORE, RESUME, and EXECUTE. ### Segmented runfiles A segmented runfile consists of segment subfiles in a segment directory. For this reason, you cannot delete a SEG runfile with a PRIMOS-level DELETE command. Instead, use the DELETE command in SEG. (The TREDEL command in FUTIL also works but is slower than SEG's DELETE.) ### Note It is good practice to use the PRIMOS DELSEG command to release segments assigned by SEG during a load session. Otherwise those segments remain assigned to the user until logout, precluding their use by anyone else. Each segment of the runfile consists of 32 ('40) subfiles of '4000 words each. Subfile 0 of the runfile is used for startup information, the load map, and the memory image subfile map. Memory image subfiles begin in segment subfile 1. Only the subfiles actually required for the runfile are stored on the disk. ### SEG's loader SEG has a virtual loader (i.e., it loads to a file rather than to memory) which requires the name of the runfile before anything is loaded. The runfile may be new or may be a previously used SEG runfile, and may be in any directory. A runfile compiled and loaded in 32R or 64R mode may not be used. As the symbol table is always available, SEG's loader may be used to add modules to an existing runfile. Similarly, a partial load may be saved with the SEG SAVE command and the load completed later. In addition, selected modules may be replaced in a SEG runfile. ### Object files Object files of the program modules must have been created using the SEG or SEGR pseudooperation. Modules written in other languages may also be loaded, if they have been compiled or assembled in 64V or 32I mode. Code and data are loaded in separate segments to support re-entrant procedures. Data includes all COMMON blocks and link frames. The loader assigns code and data segments. The first segment ('4001) is used for code. Usually segment '4002 will be used for data. The loader loads data and code into appropriate segments and opens new segments as required. It is possible to put both code and data in the same segment to save space, using the MIXUP subcommand of the LOAD subprocessor. ### The stack The loader assigns a stack (a dynamic work area) when SAVE or EXECUTE is invoked. The stack is usually assigned as the next free location in the first procedure segment with '6000 free words. If no such segment exists, a new data segment is assigned with the first location in the stack set to 4; locations 0 to 3 are used for internal SEG information. The user may force the location of the stack and/or may change its size. ### Use of pathnames Pathnames can be used to specify object files in all commands except LIBRARY, which accepts only a simple filename of a file within the LIB UFD. ### Base areas Base areas normally present no problem unless the following message is printed: SECTOR 0 BASE AREA FULL This condition, which is extremely unlikely to occur, can be avoided by using the SETBASE command or the SETB pseudo-operation to designate a base area where it is required. ### **Locating COMMON** SEG makes sure there is no overlap of procedures and COMMON. The user has the option of moving COMMON by a COMMON or SYM command, but he takes on the responsibility of making sure it doesn't run into the stack. ### **COMMAND SUMMARY** Following is a summary of all SEG commands, in alphabetical order within three groups: - 1. SEG-level commands - 2. LOAD-subprocessor - 3. MODIFY subprocessor Files and directory names may be specified by pathnames, except in the LIBRARY commands. All numerical values must be octal. The following conventions are followed for parameters. addr Word address within a segment. segno Segment number. psegno Procedure segment number. lsegno Linkage segment number. [a][b][x] Values for A, B, and X registers. ### Note Segment numbers may be absolute or relative. ### SEG-LEVEL COMMANDS Commands at SEG level are entered in response to the "#" prompt. ### **DELETE** [pathname] Deletes a saved SEG runfiles. ### HELP Prints abbreviated list of SEG commands at terminal. ### [V]LOAD[pathname] Defines runfile name and invokes virtual loader for creation of new runfile (if name did not exist) or appending to existing runfile (if name exists). If **pathname** is omitted, SEG requests one. ### MAP pathname-1 [pathname-2] [map-option] Prints a loadmap of runfile (pathname-1 or current loadfile (\*)) at terminal or optional file (pathname-2). ### Option Load Map information - 0 Full map (default) - 1 Extent map only - 2 Extent map and base areas - 3 Undefined symbols only - 4 Full map (identical to 0) - 5 System programmer's map - 6 Undefined symbols, alphabetical order - 7 Full map, sorted alphabetically - 10 Symbols by ascending address - 11 Symbols alphabetically ### MODIFY [filename] Invokes MODIFY subprocessor to create a new runfile or modify an existing runfile. ### PARAMS [filename] Displays the parameters of a SEG runfile. ### PS<sub>D</sub> Invokes VPSD debugging utility. ### **OUIT** Returns to PRIMOS command level and closes all open files. ### RESTORE [pathname] Restores a SEG runfile to memory for examination with VPSD. ### **RESUME** [pathname] Restores runfile and begins execution. ### SAVE [pathname] Synonym for MODIFY. ### SHARE [pathname] Converts portions of SEG runfile corresponding to segments below '4001 into R-mode-like runfiles. ### SINGLE [pathname] segno Creates an R-mode-like runfile for any segment. ### TIME [pathname] Prints time and date of last runfile modification. ### VERSION Displays SEG version number. **VLOAD** See LOAD. ### LOAD SUBPROCESSOR COMMANDS ### ATTACH [ufd-name] [password] [ldisk] [key] Attaches to directory. ### A/SYMBOL symbolname [segtype] segno size Defines a symbol in memory and reserves space for it using absolute segment numbers. Relocates COMMON using absolute or relative segment numbers. Continues a load using parameters of previous load command. ### Note D/ and F/ may be combined, as in D/F/LI. ### EXECUTE [a] [b] [x] Performs SAVE and executes program. $$F/\left\langle\begin{array}{c}IL\\LOAD\\LIBRARY\\FORCELOAD\\PL\\RL\end{array}\right\rangle [pathname][addr\ psegno\ lsegno]$$ Forceloads all routines in object file. ### IL [addr psegno lsegno] Loads impure FORTRAN library IFTNLB ### INITIALIZE [pathname] Initializes and restarts load subprocessor. ### LIBRARY [filename] [addr psegno lsegno] Loads library file (PFTNLB and IFTNLB if no filename specified). ### LOAD [pathname] [addr psegno lsegno] Loads object file. ### MAP [pathname] option Generates load map (see SEG-level MAP command). $$MIXUP \left\{ \begin{bmatrix} ON \\ OFF \end{bmatrix} \right\}$$ Mixes procedure and data in segments and permits loading of linkage and common areas in procedure segments. *Not* reset by INITIALIZE. ### MV [start-symbol move-block desegno] Moves portion of loaded file (for libraries). If options are omitted, information is requested. ### **OPERATOR** option Enables or removes system privileges 0=enable, 1=remove. Caution: this command is intended only for knowledgeable creators of specialized software. ### PL [addr psegno [segno] Loads pure FORTRAN library, PFTNLB. $$P/\left\{\begin{array}{c} IL\\ LOAD\\ LIBRARY\\ FORCELOAD\\ PL\\ RL \end{array}\right\} [pathname] \ option \ [psegno] \ [lsegno]$$ Loads on a page boundary. The **options** are: PR=procedure only, DA=link frames only, none =both procedure and link frames. ### **QUIT** Performs SAVE and returns to PRIMOS command level. ### RETURN Performs SAVE and returns to SEG command level. ### RL pathname [addr psegno lsegno] Replaces a binary module in an established runfile. ### R/SYMBOL symbol-name [segtype] segno size Defines a symbol in memory and reserves space for it using relative segment assignment. (Default=data segment). ### **SAVE** [a] [b] [x] Saves the results of a load on disk. ### SETBASE segno length Creates base area for desectorization. Splits segment into data and procedure portions. Formats 2 and 3 allow R mode execution if all loaded information is in segment 4000. ### SS symbol-name Saves symbol; prevents XPUNGE from deleting symbol-name. ### STACK size Sets minimum stack size. ### SYMBOL [symbol-name] segno addr Defines a symbol at specific location in a segment. Loads an object file in specified absolute segments. ### XP dsymbol dbase Expunges symbol from symbol table and deletes base information. ### symbol Action - 0 Delete all defined symbols—including COMMON area. - Delete only entry points, leaving COMMON areas. ### dbase Action - 0 Retain all base information. - 1 Retain only sector zero information. - 2 Delete all base information. ### MODIFY SUBPROCESSOR COMMANDS ### NEW pathname Writes a new copy of SEG runfile to disk. ### PATCH segno baddr taddr Adds a patch (loaded between baddr and taddr) to an existing runfile and saves it on disk. ### **RETURN** Returns to SEG command level. Specifies stack size (ssize) and location. esegno specifies an extension stack segment. ### START segno addr Changes program execution starting address. ### WRITE Writes all segments above '4000 of current runfile to disk. This section treats the following topics: - Execution of program memory images saved by the linking loader. - Execution of segmented runfiles saved by SEG's loader. - Installation of programs in the command UFD (CMDNC0). - Use of run time. ### **EXECUTION OF UNSEGMENTED RUNFILES** Use the PRIMOS RESUME command to execute an unsegmented runfile: ### RESUME pathname where pathname is an R-mode runfile in the current UFD. Programs which are resident in the user's memory may be executed by a START command: ### **START** ### **RESUME** RESUME brings the memory-image program **pathname** from the disk into the user's memory, loads the initial register settings, and begins execution of the program. Its format is: ### RESUME pathname Example: OK, R \*TEST User requests program GO Execution begins THIS IS A TEST Output of program OK, PRIMOS requests next command RESUME should not be used for segmented (64V or 32I mode) programs; use the SEG command (discussed later) instead. ### **START** Once a program is resident in memory (e.g., by a previous RESUME command) you can use START to initialize the registers and begin execution. Its format is: ### START [start-address] Upon completion of the program, control returns to PRIMOS command level. ### **EXECUTION OF SEGMENTED RUNFILES** Use the SEG command to begin execution of a segmented program; e.g. **SEG pathname** where **pathname** is a SEG runfile. SEG loads the runfile into segmented memory and starts execution. SEG should be used for runfiles created by SEG's Loader; it should not be used for program memory images created by the LOAD utility. Example: | GO | user requests program execution begins output of program | |-----|----------------------------------------------------------| | OK, | PRIMOS requests next command | Upon completion of program execution, control returns to the PRIMOS command level. You may restart a SEG runfile by the command: S 1000, provided both the SEG runfile and the copy of SEG used to invoke it are in memory. ### INSTALLATION IN THE COMMAND UFD (CMDNC0) Run-time programs in the command UFD (CMDNC0) can be invoked by keying in the program name alone. This feature of PRIMOS is useful if a number of users invoke this program. Only one copy of the program need reside on the disk in UFD CMDNC0. Even more space is saved during execution by multiple users if the program uses shared code (64V and 32I mode only). ### Program memory images saved by LOAD Installation in the command UFD is extremely simple, providing you have access to the password. The runtime version of the program is copied into UFD CMDNC0 using PRIMOS' FUTIL file handling utility. Example: Assume you have written a utility program called FARLEY. This utility acts as a "tickler" for dates. Using FARLEY, each user builds a file with important dates. The FARLEY utility program, upon request, prints out upcoming events or occasions of interest to the user. ### Note This utility does not necessarily actually exist; it is used as a plausible example. First, assemble the program. ``` OK, PMA FARLEY -64R Assemble in 64R mode GO ØØØØ ERRORS (PMA-REV 16.2)ASSEMBLER MESSAGE OK, LOAD Invoke the Loader GO $LO B FARLEY Load the object file; the default name is used $Load other required modules ``` \$LI Load the FORTRAN library LOAD COMPLETE Load is complete \$SA \*FARLEY Save the memory image \$QU Return to PRIMOS OK, FUTIL Invoke the file utility GO >TO CMDNCØ ORDER Defines the TO UFD as CMDNCØ: password is ORDER >COPY \*FARLEY FARLEY Copies the runtime program \*FARLEY into UFD=CMDNCØ under the name of FARLEY Asks for future time period >QUIT Return to PRIMOS Command level Recult to Primos Command Tevel OK, It was not necessary to define a FROM UFD: the default was used. Any user can now invoke this program: OK, FARLEY Invoke program GO Execution beings HOW FAR: Asks for future time r etc. ### Segmented runfiles saved by SEG's loader A segmented program cannot be run directly from UFD CMDNC0 because PRIMOS' command processor cannot directly handle the SEG runfiles. The segmented program may be invoked by means of a non-segmented interlude program in CMDNC0. The procedure for creating an interlude is: - 1. Create the desired SEG runfile. - 2. Attach to UFD SEG. - 3. Run the command file CMDSEG; it will ask for a runfile name—this name is the new SEG runfile name used in step four. This command file will create the interlude program under the name \*TEST. - 4. Make a copy of the SEG runfile in UFD SEG using FUTIL's TRECPY command. The name of the new SEG runfile should be the name used in step three. - 5. A copy of \*TEST should be placed in UFD CMDNC0 using FUTIL's COPY command. The file name should be that by which the program will be invoked. ### Note If a pathname is given in step three, the runfile need not reside in UFD SEG (step four can be skipped). ### Example: 1. Extensions to the FARLEY utility described above make it desirable to assemble and load it as a segmented program. ``` Assemble in 64V mode OK, PMA FARLEY -64V GO ØØØØ ERRORS (PMA-REV 16.2) Invoke SEG utility OK, SEG GO Establish runfile name # LOAD #FARLEY Load object file $ LO B FARLEY $. $ LI Load 64V mode FORTRAN library Save the file $ SA Return to PRIMOS $ QU OK, 2. Attach to UFD SEG. OK, A SEG OK, The command file CMDSEG creates the interlude program. OK, CO CMDSEG OK, * CMDSEG, SEG, CEH. 04/05/78 OK, * COMMAND.FILE.TO.CREATE.'CMDNCØ'.SEG.RUNFILES OK, R *CMDMA GO RUN FILE NAME: FARLEY OK, PMA S$$SEG 1/5707 GO ØØØØ ERRORS (PMA-REV 16.2) OK, FILMEM OK, LOAD $SZ $ER 2 $MO D64R $CO 173400 $LO B S$$SEG 173400 $AU 2 $LO CMDLIB * 12 14 14 0 0 12 0 0 12 $AU Ø $LI $MA 2 ``` \$SAVE \*TEST \$AT ``` $QU OK, DELETE S$$SEG OK, DELETE B_$$SEG OK, CO TTY OK, ``` 4. UFD SEG contains the SEG runfiles which are actually executed by the interlude programs. The SEG runfile is copied here from the UFD in which it was SAVEd. OK, FUTIL Invoke FUTIL GO >FROM MYUFD FROM UFD is user's old home UFD >TRECPY #FARLEY FARLEY Make a copy under the invocation ### Note No TO UFD is defined since the default (home) is being used. 5. The interlude program \*TEST is copied into the command UFD under the name by which it will be invoked. >FROM \* New FROM UFD - the current home TO UFD=CMDNCØ; password here is assumed to be ORDER >COPY \*TEST FARLEY >QUIT Copy the interlude Return to PRIMOS command level OK, • When FARLEY is entered at the user terminal, the FARLEY interlude program in CMDNC0 is executed. This program attaches to the SEG UFD, restores the segmented runfile FARLEY, re-attaches to the user's home UFD and begins execution of the SEG runfile. If the SEG runfile requires only one segment of loaded information (procedure, link frames, and initialized common) in user space (segment '4000 and above) it is possible to include the interlude in the SEG runfile. ### RUN-TIME ERROR MESSAGES Appendix C contains a list of error messages which you may receive during execution, along with their meaning and origin. ## Debugging Debugging is really an art and an attitude, rather than a set of techniques. In accord with this, we will present some tools and we hope you will use them, develop your own ideas, and tell us about them. ### **TOOLS** You have a variety of tools from which to choose. Which you select is extremely context sensitive. The partial list below is intended to be an initial guide. | 1 001 | wnere Described | |---------------------|-----------------------------------| | PM command | Described below | | COMOUTPUT command | Described below | | PMA Error Messages | Appendix C of this document | | Load Maps | Sections 4 and 5 of this document | | Debugging Utilities | Sections 18-21 of this document | ### **RVEC** parameters The commands RESTORE, RESUME, SAVE, PM, and START process a group of optional parameters associated with the PRIMOS RVEC vector. These parameters are stored on disk along with a starting address (SA) and ending address (EA), for every program saved by the SAVE command. Initial values for the RVEC parameters are usually specified in the PRIMOS SAVE command, or by the Loader's SAVE command that stored the program on disk. Each parameter is a 16-digit processor word represented by up to six octal digits. ### PM command The PM (Post Mortem) command prints the contents of the RVEC vector. PRIMOS first prints labels for the items in RVEC, then prints the values on the line in the same order. PM is an internal command and does not overlay user memory. The Prime 350 and above contain additional registers which PM displays: the procedure base register (PB), the stack base register (SB), the link base register (LB), and the temporary base register (XB). These 32-bit registers are displayed at the user terminal on a text line separate from the other registers. Each of the Prime 400 registers is displayed as two 16-bit octal numbers separated by a slash (/) character. ### Example: ``` OK, PM SA,EA,P,A,B,X,K= 100 11763 5517 120240 20061 23534 14000 PB,SB,LB,XB: 62000/5517 64000/74012 4000/3400 11/15041 ``` The above example of PM under PRIMOS IV shows a PB of 64000/3043, which indicates: ring 3 (See the System Architecture Guide for a discussion of rings), segment '4000. The word number portion of PB indicates the same number as the P parameter of PM. This number specified the location within the segment to execute the next instruction upon possible receipt of a START command. The other base registers shown in the example contain a 0, indicating that they have not been used since LOGIN. Programs that run in one of the Prime 300 addressing modes use segment 4000 ring 3, and give values as a result of invoking PM in the form shown by the example. ### **COMOUTPUT** files PRIMOS has a very useful tool for anyone who is debugging — or who wishes to record a particular situation. You may direct all the interactive terminal dialog to a file. This means that you can have a complete trace of a debugging session without a hard copy terminal. In addition, you can edit this file, print it out and delete it as you chose. The command is: ### **COMOUTPUT** pathname where pathname is the output file. To stop the COMO file creation process, type: COMO -END ### ADVANCED DEBUGGING TECHNIQUES Section 9—Instruction and Data Formats, contains useful debugging data structures, such as ECB and stack frame layouts ### **DEBUGGING—PRIMOS SEVERE ERRORS** The following list describes several severe error conditions. In all cases the errors are fatal. NO VECTOR A fault occured and there is no user vector in segment '4000 to process it. There are several possibilities as to why this condition occurs: 1. Stack Overflow—Usually there is no vector because the stack is too small. Do a PM. If SB is close to top of its segment use SEG to move stack and increase its size, or create a stack extension. With the dynamic variables features of FTN, stack overflow may become a problem. 2. FLEX (Floating Point Exception) If this occurs, your program has wiped out segment '4000. Check to see that you are using '4000 properly. If so, your program is sick. To ascertain this, examine location '74 with PSD or TAP. If 0 then it is wiped out. 3. Others. The implication is that your program has gone off into random memory and has wiped things out. POINTER FAULT Either there is a missing argument for some subroutine call, you did not get a load complete when loading, or the program has written over its link frame and/or procedure segment. Use VPSD to examine the current stack frame and SEG to get a MAP 3 or MAP 6. ILLEGAL SEGNO Probably some pointer in a link or stack frame has been wiped out (i.e., referencing an array with subscripts out-of-range). Use VPSD to examine the current and past link and stack frames. ACCESS VIOLATION An attempt was made to access a segment for which the user does not have proper access rights. Cause usually the same as an illegal segno ### Note Most frequent cause of ILLEGAL SEGNO and ACCESS VIO-LATION is an improperly dimensioned local or common array. Try getting common away from link frames by reloading. ### MEMORY OVERFLOW ERRORS (MO) As user programs become larger, MO (memory overflow) errors will become more common. Several causes and solutions to these errors follow: When an MO error occurs, do a MA 2 and examine the resulting map for any of the following situations: - The address of the bottom of the symbol table (\*SYM) is at or close to PBRK. This indicates that there is insufficient room below the loader for the whole program. Using HILOAD will probably solve the problem, unless of course the user is already using HILOAD. If this is the case there are only two alternatives; redesign the entire program or make hardware changes. - 2. The sector zero base area is full. The next free location is '1000. The size of the sector zero base area may be increased by using a SETB 100 command at the beginning of the load (if locations 100 to 200 are free). An AU xx command may be used to insert base areas throughout the load, where xx is a small octal number which sets the size of the base area to be inserted. - 3. \*CMLOW is higher than \*CMHGH. The total size of all the common blocks is too large causing common to wrap around through zero to high memory. Possibly common may be moved to the top of memory, if not already done. If there is more than 64K of common, and this cannot be reduced, the program cannot be run in "R"mode. A segmented program is required. - 4. Others. The program requires initialized common. Common is usually defaulted to overwrite the space used by the Loader. The locations between the bottom of the symbol table and the top of the loader cannot be initialized. This would destroy the loader. Use a COMMON command to move common out of the way of the loader. HILOAD can be used to permit common to utilize locations normally used by LOAD. 1 March, 1979 7–3 FDR 3059 # Interfacing with the system libraries Most of the commonly used subroutines — I/O, math functions and EXIT, are either embedded in the operating system or are in one of the FORTRAN libraries. LOAD and SEG automatically load the appropriate library when you type the command LI during a loading sequence. Other libraries, such as APPLIB and MATHLIB require the specification of their name following LI — e.g. LI APPLIB causes the application library to be searched for unresolved references. Table 8–1 lists the commonly available system libraries. See the Reference Guide, PRIMOS Subroutines for complete descriptions of the system subroutines. All routines, regardless of mode, should use the CALL pseudo-operation to call subroutines. S and R-mode arguments use DAC pointers; V, and I-mode arguments use AP pointers (see Section 16 for the DAC and AP pseudo-operation formats). Figure 8–1 illustrates the SR calling sequences and associated subroutine code; Figure 8–2 illustrates VI calling sequences and associated subroutine code. | Table 8-1. System Libr | aries | | |------------------------|--------------------------------------|------| | Name | Description | Mode | | FTNLIB | FORTRAN Library | R | | PFTNLB | FORTRAN Library pure pro-<br>cedures | v | | IFTNLB | FORTRAN Library impure procedures | v | | APPLIB | Application Library | R | | VAPPLB | Application Library | V | | SRTLIB | Sort Library-Files | R | | VSRTLI | Sort Library-Files | V | | MSORTS | Sort Library-Memory | R | | MATHLB | Matrix Routines | R | | No Arguments | | Main Program<br>One Argument | Tv | wo or More Argui | nents | |------------------------------|--------|-------------------------------------|--------|-----------------------------------------------------|-------| | CALL SUBX | | CALL SUBX<br>DAC A | | CALL SUBX DAC A DAC B DAC C | | | | | Subr | outine | | | | ENT SUBX REL SUBX DAC ** | | ENT SUBX REL DAC ** | SUBX | ENT SUBX REL | | | first instruction | | CALL F\$AT<br>DEC 1<br>DAC** | BPTR | CALL F\$AT DEC 3 DAC ** DAC ** DAC ** first instruc | tion | | | | JMP SUBX,* | | JMP SUBX,* | | | | | Note | | | | | | ильь о | UBX is equivalent EXT SUBX JST SUBX | . 10. | | | | | | | | | | | | | | | | | | Figure 8-1. SR Subroutine Ca | ALL Co | onventions | | | | | CALL SUBX CALL SUBX AP A,S AP B,S AP C,S AP n,SL Subroutine ENT SUBX,SBX1 ENT SUBX,SBX1 ENT SUBX,SBX1 SEG SEG SEG SUBX first instruction SUBX ARGT SUBX ARGT first instruction first instruction PRIN PRIN PRIN PRIN LINK SBX1 ECB SUBX DYNM APTR(3) LINK SBX1 ECB SUBX DYNM APTR(3) DYNM DPTR(3) DYNM DPTR(3) DYNM DPTR(3) DYNM DPTR(3) LINK SBX1 ECB SUBX,APTR,1 Note CALL SUBX is equivalent to: EXT SUBX PCL SUBX PC P | No Argun | nents | | | Main Program One Argument | T | wo or | More Arguments | |--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------|--------|-------------|---------|---------------------------|------|-------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | AP A,SL AP A,S AP B,S AP C,S | | | | | | | | | | AP A,SL AP A,S AP B,S AP C,S | | | | | | | | | | AP C,S | | CALL S | SUBX | | | | AP | A,S | | Subroutine ENT SUBX,SBX1 ENT SUBX,SBX1 ENT SUBX,SBX1 SEG SEG SEG SUBX first instruction SUBX ARGT first instruction | | | | | | | AP | | | Subroutine ENT SUBX,SBX1 ENT SUBX,SBX1 ENT SUBX,SBX1 SEG SEG SEG SUBX first instruction SUBX ARGT first instruction | | | | | | | • | ne de la merce de la competition de la competition de la competition de la competition de la competition de la<br>La competition de la competition de la competition de la competition de la competition de la competition de la | | ENT SUBX,SBX1 SEG SUBX first instruction SUBX ARGT first instruction PRIN PRIN PRIN PRIN PRIN PRIN PRIN SBX1 ECB SUBX DYNM APTR(3) LINK SBX1 ECB SUBX DYNM APTR(3) DYNM APTR(3) DYNM APTR(3) DYNM APTR(3) DYNM CPTR(3) DYNM DPTR(3) DYNM DPTR(3) DYNM DPTR(3) LINK SBX1 ECB SUBX,APTR,1 Note CALL SUBX is equivalent to: EXT SUBX | | | | | | | | n,SL | | SEG SUBX first instruction SUBX ARGT first instruction PRTN PRTN PRTN PRTN PRTN PRTN PRTN PRT | | | | | Subrout | ine | | | | first instruction PRTN PRTN PRTN PRTN PRTN LINK SBX1 ECB SUBX DYNM APTR(3) LINK SBX1 ECB SUBX DYNM APTR(3) DYNM APTR(3) DYNM CPTR(3) DYNM CPTR(3) DYNM DPTR(3) DYNM DPTR(3) LINK SBX1 ECB SUBX,,APTR,1 Note CALL SUBX is equivalent to: EXT SUBX | | SEG | | <b></b> | 252 | | SEG | SUBX,SBX1 | | LINK SBX1 ECB SUBX DYNM APTR(3) LINK SBX1 ECB SUBX,,APTR,1 DYNM CPTR(3) DYNM DPTR(3) DYNM DPTR(3) LINK SBX1 ECB SUBX,,APTR,n Note CALL SUBX is equivalent to: EXT SUBX | SUBX | tirst | instruction | SUBX | | | | instruction | | LINK SBX1 ECB SUBX DYNM APTR(3) LINK SBX1 ECB SUBX, APTR, 1 SBX1 ECB SUBX, APTR, 1 DYNM DPTR(3) DYNM DPTR(3) LINK SBX1 ECB SUBX, APTR, n Note CALL SUBX is equivalent to: EXT SUBX | | | | | | | · | | | SBX1 ECB SUBX DYNM APTR(3) LINK DYNM BPTR(3) SBX1 ECB SUBX,,APTR,1 DYNM CPTR(3) DYNM DPTR(3) DYNM DPTR(3) LINK SBX1 ECB SUBX,,APTR,n Note CALL SUBX is equivalent to: EXT SUBX | | PRTN | | | PRTN | | PRTN | | | SBX1 ECB SUBX DYNM APTR(3) LINK DYNM BPTR(3) SBX1 ECB SUBX,,APTR,1 DYNM CPTR(3) DYNM DPTR(3) DYNM DPTR(3) LINK SBX1 ECB SUBX,,APTR,n Note CALL SUBX is equivalent to: EXT SUBX | | •<br>• | | | | | • | | | SBX1 ECB SUBX,,APTR,1 DYNM CPTR(3) DYNM DPTR(3) DYNM nPTR(3) LINK SBX1 ECB SUBX,,APTR,n Note CALL SUBX is equivalent to: EXT SUBX | | | SUBX | | | | | | | LINK SBX1 ECB SUBX,,APTR,n Note CALL SUBX is equivalent to: EXT SUBX | | | | SBXl | ECB SUBX,, APTR, 1 | | DYNM | CPTR(3) | | LINK SBX1 ECB SUBX,,APTR,n Note CALL SUBX is equivalent to: EXT SUBX | | | | | | | • | | | Note CALL SUBX is equivalent to: EXT SUBX | | | | | | | | nPTR (3) | | CALL SUBX is equivalent to: EXT SUBX | | | | | | SBX1 | ECB S | SUBX,,APTR,n | | CALL SUBX is equivalent to: EXT SUBX | | | | | Note | | | | | | | | C | ALL S | | : | | | | | | | | | | | | | Figure 8-2. VI Subroutine CALL Conventions ### MACHINE FORMATS AND INSTRUCTIONS ### Data and instruction formats · SRVI ### **DATA STRUCTURES** ### Word length - 16 bits (SRV) - 32 bits (I) ### Byte length • 8 bits (SRVI) ### Character strings • Variable length collection of bytes from 1 to 2\*\*17-1. ### Numbers - Unsigned 16 bit integers (SRV) Unsigned 32 bit integers (SRVI) Unsigned 64 bit integers (I) Signed 16-bit integers (SRVI) | 17 | | 24 25 | | | 32 | |----|----------------------|---------|-------------------------|------------------|------------------| | | MANTISSA | | EXPONENT ( | 8) | | | 1 | 2 | | - | 16 | S = 1 = negative | | S | | М | IANTISSA | S = 0 = positive | | | | • Floating Point - S | Single | Precision 32 bits (RVI) | | | | 1 | 2 | 32 | 33 | 64 | S = 1 = negative | | S | | | | | S = 0 = positive | | | • Signed 64-bit into | egers ( | VI) | | | | 1 | 2 | 16 | 17 | 32 | S = 1 = negative | | S | | | | | S = 0 = positive | | | • Signed 32-bit into | egers ( | VI) | | | | 1 | 2 | 16 | 17 | 32 | S = 1 = negativ | | S | | | 0 | | S = 0 = positiv | | | • Signed 31-bit into | egers ( | (SR) | | | | 1 | 2 | | | 16 | S = 1 = negativ | | S | | | | | S = 0 = positive | • Floating Point - Double Precision 64 bits (RVI) • Decimal - one to 63 digits in five forms (VI) ### Decimal control word format (VI) To specify the characteristics of the operation to be performed, most decimal arithmetic instructions require a control word to be loaded in the L register (general register 2 in I-Mode). The general format is as follows: | A | _ | В | С | _ | Т | D | E | F | G | Н | | | |-------------------------------------------------------------------------------------------|--------|------|-----|----|----|----|---------------------------------------------------------------------|-----------------------|------------|----------|--|--| | 1-6 | 7 | В 9 | 10 | 11 | 12 | 13 | 14-16 | 17-22 | 23-29 | 30-32 | | | | <b>A</b> (E | Bits : | l-6) | | | | | Field | 1, numb | er of dig | gits | | | | <b>E</b> (E | lits 1 | 4-1 | 6) | | | | Field | 1, decir | nal data | type | | | | <b>B</b> (Bit 9) If set, sign of field 1 is treated as opposit value. | | | | | | | | | | | | | | C (Bit 10) If set, sign of field 2 is treated as opposite value. XAD, XMP, XDV, XCM only | | | | | | | | | | | | | | <b>D</b> (Bit 13) Roun | | | | | | | | Round flag (XMV only) | | | | | | <b>F</b> (E | its 1 | 7-2 | 2) | | | | Field | 2, numl | per of dig | gits | | | | H (1 | 3its | 30-3 | 32) | | | | Field | 2, decir | nal data | type | | | | G (H | Bits | 23-2 | 29) | | | | Scale differential (XAD, XMV, XCM and num multiplier digits in XMP) | | | | | | | <b>T</b> (E | 3it 1 | 2) | | | | | Gene | rate pos | itive res | ults alw | | | | | | | | | | | Unus | ed, mus | t be zero | 1 | | | The fields used by each instruction are listed in the instruction descriptions. Fields not used by an instruction must be zero. The scale differential specifies the difference in decimal point alignment between the operator and fields for some instructions. This field is treated as a signed 7 bit two's complement number. Its value is specified as Fx=F1-F2, where Fx is the number of fractional digits in Field x. A positive value indicates a right shifting of Field 1 with respect to Field 2, and a negative value indicates a left shifting. ### Address pointer (AP) (VI) Two word pointer which follows AP instructions. # Indirect word - one word memory reference (SRV) # Indirect pointer - two word memory reference (IP) (VI) | | F | RR | 0 | | SEGNO | | | WORDNO | | | |-------------------------------------------------------|---|-----|---|---|-------|------------------------------------------------------------------------------------------------------------------------------------------|----|--------|--|--| | | 1 | 2-3 | 4 | 5 | 1 | 6 | 17 | 32 | | | | <b>F</b> (Bit 1) | | | | | | Generate pointer fault if set. In the fault case, the entire first word (bits 1–16) forms a fault code, and no other bits are inspected. | | | | | | <b>RR</b> (Bits 2–3) | | | | | Ri | Ring of privilege – controls access rights | | | | | | Bit $4 = 0$ | | | | | | No third word. Bit number portion of effective address is zero. | | | | | | <b>SEGNO</b> (Bits 5–16)<br><b>WORDNO</b> (Bit 17–32) | | | | | | The segment number portion of the effective address. The word number portion of the effective address. | | | | | # Indirect pointer - three word memory reference (IP) (VI) | F | RR | 1 | SE | GNO | WOR | DNO | ВІТ | NO | | | |-------------|-------|-----|-----|-----|-----|-------------------------------|----------------------------------|----------|------|--------------| | 1 | 2-3 | 4 | 5 | 16 | 17 | 32 | 33 | 36 | 37 | 48 | | <b>F</b> (F | 3it 1 | .) | | | | Genera<br>entire f<br>other b | te poin<br>irst wor<br>its are i | d (bits | 1-16 | set<br>3) fo | | RR | (Bit | s 2 | -3) | | | Ring of | privile | ge – co: | ntro | ls a | | Bit | 4 = | : 1 | | | | The thi portion | rd word | | | | **SEGNO** (Bits 5–16) **WORDNO** (Bit 17–32) **BITNO** (Bits 33–48) The segment number portion of the effective address. The word number portion of the effective address. The bit number portion of the effective address. # Stack segment header (VI) | 0 1 | FREE POINTER | |-----|---------------------------| | 2 3 | EXTENSION SEGMENT POINTER | | Word | Meaning | |------|-----------------------------------------------------------------------| | 0,1 | Free pointer - segment number/word number of available location at | | , | which to build next frame. Must be even. | | 2.3 | Extension segment pointer - segment number/word number of loca- | | _,- | tions at which to build next frame when current segment overflows. If | | | zero, a stack overflow fault occurs when current segment overflows. | # PCL stack frame header (VI) | 0 | 0 - 0 | |---|---------------------------| | 1 | STACK ROOT SEGMENT NUMBER | | 2 | RETURN POINTER | | 4 | CALLER'S SAVED STACK | | 5 | BASE REGISTER | | 6 | CALLER'S SAVED LINK | | 7 | BASE REGISTER | | 8 | CALLER'S SAVED KEYS | | 9 | LOCATION FOLLOWING CALL | | Word<br>0<br>1<br>2,3<br>4,5<br>6,7 | Meaning Flag bits – set to zero by PCL when frame is created Stack root segment number – for locating free pointer Return pointer – segment number/word number of return location Caller's saved stack base register Caller's saved link base register Caller's saved keys | |-------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 9 | Word number of location following call - beginning of argument transfer templates, if any | # CALF stack frame header (VI) | 0 | FLAG BITS | |----------------|---------------------------------------| | 1 | STACK ROOT SEGMENT NUMBER | | <b>2</b> 3 | RETURN POINTER | | 4<br>5 | CALLER'S SAVED STACK<br>BASE REGISTER | | 6<br>7 | CALLER'S SAVED LINK<br>BASE REGISTER | | 8 | CALLER'S SAVED KEYS | | 9 | LOCATION FOLLOWING CALL | | 10 | FAULT CODE | | 11<br>12 | FAULT ADDRESS | | 13<br>14<br>15 | RESERVED | | Word | Meaning | | | | |-------|-------------------------------------------------------------------------------------------|--|--|--| | 0 | Flag bits – set to one by CALF fault | | | | | 1 | Stack root segment number - for locating free pointer | | | | | 2,3 | Return pointer - segment number/word number of return location | | | | | 4,5 | Caller's saved stack base register | | | | | 6,7 | Caller's saved link base register | | | | | 8 | Caller's saved keys | | | | | 9 | Word number of location following call - beginning of argument transfer templates, if any | | | | | 10 | Fault code | | | | | 11,12 | Fault address | | | | | 13-15 | Reserved | | | | 1 March, 1979 9-5 FDR 3059 # Entry control block (ECB) (VI) | 0 | POINTER TO CALLED | |----|----------------------------| | 1 | PROCEDURE | | 2 | STACK FRAME SIZE | | 3 | STACK ROOT SEGMENT NUMBER | | 4 | ARGUMENT LIST DISPLACEMENT | | 5 | NUMBER OF ARGUMENTS | | 6 | LINK BASE REGISTER OF | | 7 | CALLED PROCEDURE | | 8 | KEYS | | 9 | | | 10 | | | 11 | | | 12 | RESERVED | | 13 | | | 14 | | | 15 | | | Word | Meaning | |------|---------------------------------------------------------------------------------------------------| | 0,1 | Pointer (ring, segment, word number) to the first executable instruction of the called procedure. | | 2 | Stack frame size to create (in words). Must be even. | | 3 | Stack root segment number. If zero, keep same stack. | | 4 | Displacement in new frame of where to build argument list. | | 5 | Number of arguments expected. | | 6,7 | Called procedure's link base (location of called procedure's linkage frame less '400). | | 8 | CPU keys desired by called procedure. | | 9-15 | Reserved, must be zero. | Entry control blocks which are gates must begin on a 0 modulo 16 boundary, and must specify a new stack root. # Queue control block (VI) | 1 | | TOP POINTER | 16 | |----|-------|--------------------|----| | 17 | E | SOTTOM POINTER | 32 | | ٧ | 000 | HIGH ORDER ADDRESS | | | 33 | 34 36 | 37 | 48 | | 49 | | SIZE MASK | 64 | | Bits | Meaning | |--------|----------------------------------------------------| | 1-16 | Top pointer-read | | 17-32 | Bottom pointer-write | | 33 (V) | Virtual/physical control bit | | | 0 physical queue<br>1 virtual queue | | 34-36 | Reserved – must be zero | | 37-48 | Queue data block address | | | Segment number if virtual queue | | | High order physical address bits if physical queue | | 49-64 | Mask – value 2**K-1 | Queue control blocks must start on word boundaries which are divisible by four, if used for DMQ. If not, a performance penalty is imposed, but the queue will work. # Argument transfer template (AP) (VI) BR L | 1-4 5 6 7-8 9 10 11-16 | 17 32 | |--------------------------------------|---------------------------------------------------------------------------------------------------| | B (Bits 1-4) I (Bit 5) BR (Bits 7-8) | Bit number Indirect bit Base register 00 Procedure base (PB) 01 Stack base (SB) 10 Link base (LB) | | <b>L</b> (Bit 9) | Last template for this call | | <b>S</b> (Bit 10) | Store argument address. Last template for this argument. | | WORDNO (Bits 17–32) | Word number offset from base register | **WORDNO** #### PROCESSOR CHARACTERISTICS # Registers (S) Prime 100, 200 and 300 registers are 16 bits wide. All the program visible registers are physically located in high speed memory and are addressed as memory locations 0-37. In restricted mode (normal user operation) only 0-7 are accessable. | Memory<br>Address | Register<br>Designation | Function | |-------------------|-------------------------|-------------------------------| | 0 | X | Index Register | | 1 | A | Arithmetic Register | | 2 | В | Extension Arithmetic Register | | 3 | | | | 4 | | | | 5 | | | | 6 | VSC | Visible Shift Count | | 7 | P | Program Counter | | 10 | PMAR (Prime 300 only) | Page Map Address Register | | 11 | FCODE | Fault Code | | 12 | FAR | Fault Address Register | | 13-17 | Reserved | | | 20-37 | DMA '20, '22, '36 | Word Pairs for DMA channels | | | (8 total) | (address and word counts) | ## Registers (R) Prime 100, 200 and 300 registers are 16 bits wide. All the program visible registers are physically located in high speed memory and are addressed as memory locations 0-37. In restricted mode (normal user operation) only 0-7 are accessable. | Memory<br>Address | Register<br>Designation | Function | |-------------------|---------------------------|-----------------------------------| | 0 | X | Index Register | | 1 | A | Arithmetic Register | | 2 | В | Extension Arithmetic Register | | 3 | S | Stack Register | | 4 | FLTH | Floating Point Accumulator – High | | 5 | FLTL | Floating Point Accumulator – Low | | 6 | FEXP | Floating Point Exponent | | 7 | P . | Program Counter | | 10 | PMAR (Prime 300 only) | Page Map Address Register | | 11 | FCODE | Fault code | | 12 | PFAR | Page Fault Address Register | | 13-17 | Reserved for microprogram | | | 20-37 | DMA '20, '22, '36 | Word Pairs for DMA channels | | | (8 total) | (address and word counts) | ## Registers (VI) Prime 350 and above registers are 32 bits wide. Short form instructions reference the same registers as in R-mode. Register addresses used in LDLR and STLR instructions are doubleword addresses. The notation "2 H" means the high, or left 16 bits of register address 2, while "2 L" means the low, or right 16 bits. The following registers should not be written into by STLR instructions, or anomalous behavior will result. PB The procedure base should be changed only via LPSW or pro- grammed transfers of control. keys The keys should be changed only via LPSW or the various mode control operations. The modals should be changed only via LPSW or the various mode modals control operations. In no case should an LPSW ever attempt to change the current register set bits of the modals. ## VI-mode register description **RATMPL** | - | c. | | | |----|------|---|-----| | 11 | efin | ш | กทร | TR Temporary Registers TR7 - Saved return pointer on a halt (automatic save) **RDMX** Register DMX RDMX1 - Used by DMC, buffer start pointer RDMX2 - REA at time of DMX trap RDMX3 - Save RD during DMQ RDMX4 - Used as working register Read Address Trap Map to RP Low RSGT Register Segmentation Trap > RSGT1 - SDW2 / address of Page Map RSGT2 - contents of Page Map / SDW2 **REOIV** Register End of Instruction Vector ZERO/ONE Constants **PBSAVE** Procedure Base Save saved return pointer when return pointer used elsewhere C377 **PSWPB** Processor Status Word Procedure Base return pointer for interrupt return (also used for Prime 300 compatibility) **PSWKEYS** Processor Status Word Keys KEYS for interrupt return (also used for Prime 300 compatibility) PPA Pointer to Process A PLA Pointer to Level A **PCBA** Process Control Block A **PPB** Pointer to Process B PLB Pointer to Level B **PCBB** Process Control Block B **DSWRMA** Diagnostic Status Word RMA RMA at last Check Trap **DSWSTAT** Diagnostic Status Word Status | DSWPB | Diagnostic Status Word Procedure Base | |---------|----------------------------------------------------| | | Return pointer or PBSAVE at last check | | RSAVPTR | Register Save Pointer | | | Location of Register Save Area after Halt | | GR | General Register | | FAR0 | Field Address Register 0 | | FLR0 | Field Length Register 0 | | FAR1 | Field Address Register 1 | | FLR1 | Field Length Register 1 | | PB | Procedure Base | | | PBH - RPH | | | PBL - 0 | | SB | Stack Base | | LB | Link Base | | XB | Temporary (auxiliary) base | | DTAR | Descriptor Table address registers | | KEYS | See below | | MODALS | See below | | OWNER | Pointer to PCB of process owning this register set | | FCODE | Fault Code | | FADDR | Fault Address | | TIMER | 1-millisecond process timer (used for time-slice) | | MICR | OCODE SCR | ATCH | D) | MX | | | | CURRENT RE | GISTER SET | (CRS) | | |------|-----------|----------|-----|------|-----------------|-----|--------------|------------|--------------------------|-------------|--------------| | RSO | | | RS1 | | | RS2 | RS3 | PRIME 3 | 100 | PRIME | PRIME | | ADR | HIGH | LOW | ADR | HIGH | LOW | ADR | ADR | HIGH | LOW | 400 | 500 | | 0 | TR0 | | 40 | _ | | 100 | 140 | ' | <del></del> | | GR0 | | 1 | TR1 | | 41 | | | 101 | 141 | | <del></del> | — | GR1 | | 2 | TR2 | | 42 | - | <u>-1</u> 0 a.c | 102 | 142 | 1{A} | 2(B) | L | GR2 | | 3 | TR3 | _ | 43 | _ | | 103 | 143 | _ | _ | E | GR3 | | 4 | TR4 | | 44 | _ | | 104 | 144 | - | <u> </u> | _ | GR4 | | 5 | TR5 | _ | 45 | _ | | 105 | 145 | 3(S) | | Y | GR5 | | 6 | TR6 | | 46 | | - | 106 | 146 | <u>—</u> | | | GR6 | | 7 | TR7 | <u></u> | 47 | | <del></del> - | 107 | 147 | 0(X) | | X | GR7 | | 10 | RDMX1 | | 50 | _ | | 110 | 150 | 13 | <del>-</del> | FALR0 | FALRO (FACO) | | 11 | RDMX2 | _ | 51 | _ | - | 111 | 151 | - | <del>-</del> | FALR0 | FALRO (FACO) | | 12 | _ | RATMPL | 52 | | _ | 112 | 152 | 4(FAC) | 5(FAC) | FALR1 (FAC) | FALR1 (FAC1) | | 13 | RSGT1 | 4 | 53 | _ | | 113 | 153 | 6(FAC) | FAC | FALR1 (FAC) | FALR1 (FAC1) | | 14 | RSGT2 | _ | 54 | | | 114 | 154 | <u> </u> | | PB | <del>-</del> | | 15 | RECC1 | | 55 | | | 115 | 155 | 14 | 15 | SB | + | | 16 | RECC2 | <u> </u> | 56 | _ | | 116 | 156 | 16 | 17 | LB | | | 17 | | REOIV | 57 | | 31 <u>24</u> | 117 | 157 | _ | 1 <del>1 </del> | XB | | | 20 | ZERO | ONE | 60 | (20) | (21) | 120 | 160 | 10 | . <del></del> | DTAR3 | 10 15 A 15 A | | 21 | PBSAVE | | 61 | | - | 121 | 161 | | 3 <del></del> 3/33/32/33 | DTAR2 | | | 22 | RDMX3 | | 62 | (22) | (23) | 122 | 162 | | - | DTAR1 | | | 23 | RDMX4 | | 63 | _ | | 123 | 163 | | | DTAR0 | | | 24 | C377 | C377 | 64 | (24) | (25) | 124 | 164 | | | KEYS/MODALS | KEYS/MODAL | | 25 | | | 65 | | | 125 | 165 | | | OWNER | | | 26 | | | 66 | (26) | (27) | 126 | 166 | 11(FCODE) | | FCODE | | | 27 | <u>-</u> | | 67 | | _ | 127 | 167 | | 12(FADDR) | FADDR | | | 30 | PSWPB | | 70 | (30) | (31) | 130 | 170 | | | TIMER | | | 31 | PSWKEYS | | 71 | | | 131 | 1 <i>7</i> 1 | | | | | | 32 | PPA:PLA | PCBA | 72 | (32) | (33) | 132 | 172 | | | | | | 33 | PPB:PLB | PCBB | 73 | | · · · · | 133 | 173 | | | | | | 34 | DSWRMA | | 74 | (34) | (35) | 134 | 174 | | | | | | 35 | DSWSTAT | | 75 | | <del></del> | 135 | 175 | | | | | | 36 | DSWPB | | 76 | (36) | (37) | 136 | 176 | | | | 1뉴및 3호 B | | 37 | RSAVPTR | | 77 | | | 137 | 177 | | | | | # General registers- 32 bits (I) The eight general registers are numbered from 0-7. 1-7 may be used for index registers. All are used as fixed point and logical accumulators in register to memory and register to register operations. # Floating point register - single precision (RVI) (2 registers in I-mode) | Prime 300 | Register<br>Prime 400 | Prime 500 | Contents | | |-----------|-----------------------|-----------|----------------------------|----| | '04 | 12H | 10H | S MANTISSA 1 2 1 | 16 | | '05 | 12L | 10L | MANTISSA 17 3 | 2 | | '06 | 13H | 11H | EXPONENT (EXCESS 128) 33 4 | 8 | 1 March, 1979 9–11 FDR 3059 # Floating point register - double precision (RVI) (2 registers in I-mode) | | Register | | Contents | | |-----------|-----------|-----------|----------------|----------| | Prime 300 | Prime 400 | Prime 500 | | | | '04 | 12H | 10H | S MANTIS | SA | | 01 | 1211 | 1011 | 1 2 | 16 | | | | | | | | '05 | 12L | 10L | MANTISSA<br>17 | 32 | | | | | 11 | | | | 101 | | MANTISSA | 4 | | '02 | 13L | 11L | 33 | 48 | | | | | | | | '06 | 13H | 11H | EXPONENT (EXC | ESS 128) | | 00 | 1011 | 1111 | 49 | 64 | # Floating point registers - 64 bits (I) The two floating point registers are numbered 0 and 1. They are used as single and double precision accumulators in register to memory and register to register operations. The two floating point registers overlap the two field length address registers on the Prime 500 and care must be used in moving between floating point and field registers. # Base registers (VI -Mode) The four base registers: | Procedure Base Register | PB | |-------------------------|----| | Stack Base Register | SB | | Link Base Register | LB | | Temporary Base Register | XB | have the following format: | 0 | RII | NG | 0 | SI | EGNO | WOR | DNO | |----|--------|----------|-------|----|--------|---------|-----| | 1 | 2 | 3 | 4 | 5 | 16 | 17 | 32 | | RI | NG (Bi | its 2–3) | | | Ring N | Vumber | | | SE | GNÒ ( | Bits 5–2 | 16) | | Segme | ent Num | ber | | WC | ORDN | O (Bits | 17-32 | 2) | Word | Number | | # Field address and length registers (VI) There are two address registers and two length registers for the manipulation of variable length fields. They overlap the floating point accumulator. | 0 | RING | 0 | SEGNO | WORDNO | LENGTH | BITNO | 0 | LENGTH | |---|------|---|-------|--------|--------|-------|---|--------| | | | | | 17-32 | | | | | RING (Bits 2-3) SEGNO (Bits 5-16) WORDNO (Bits 17-32) LENGTH (Bits 33-48, 60-64) BITNO (Bits 49-52) Ring Number Segment Number Word Number Length Bit Number The meaning of the value in the field length field depends on the data type being used. For a discussion of the available data types see the decimal and character instruction descriptions. ## Keys (SR) Process status information is available in a word called the keys, which can be read or set by the program. Its format is as follows: | С | DBL | _ | Mode | 0 | Bits | 9-16 of loca | tion 6 | | |------------|---------------|--------|------|----------------------------------------|-----------|--------------|----------|--| | 1 | 2 | 3 | 4-6 | 7-8 | 9 | | 16 | | | <b>C</b> ( | Bit 1) | | | Se | et by ari | thmetic erro | or condi | | | DB | <b>L</b> (Bit | 2) | | 0 | - Single | Precision, 1 | l – Doub | | | M | DDE (B | its 4– | 6) | The current addressing mode as follows | | | | | | | | | | | 000 | 16S | | | | | | | | | 001 | 32S | | | | | | | | | 011 | 32R | | | | | | | | | 010 | 64R | | | | | | | | | 110 | 64V | | | | | | | | | 100 | 32 I | | | **C-bit (SR)**: Bit 1 in the keys. Set by arithmetic error conditions and shifts (Bit 1). ## Keys (VI) Process status information is available in a 16-bit register known as the keys. It may be referenced by the LPSW, TKA, and TAK instructions. | С | 0 | L | MODE | F | X | LT | EQ | DEX | 0 | 1 | S | |------------|------------------------------|---|---------|---|---|----|---------------------------------|--------|----------------------------------------|----|----| | 1 | 2 | 3 | 4-6 | 7 | 8 | 9 | 10 | 11 | 12 - 14 | 15 | 16 | | <b>L</b> ( | Bit 1<br>Bit 3<br><b>DDE</b> | ) | ts 4–6) | | | I | C-Bit<br>L-Bit<br>Addre | essing | Mode: | | | | | | | | | | | 000<br>001<br>011<br>010<br>110 | | 16S<br>32S<br>32R<br>64R<br>64V<br>32I | | | | <b>F</b> (Bit 7) | Floating point exception disable: 0 take fault 1 set C-bit | |-------------------------------------|----------------------------------------------------------------------------------------------------------| | X (Bit 8) | Integer Exception enable<br>0 set C-bit<br>1 take fault | | LT (Bit 9)<br>EQ (Bit 10) | Condition code bits:<br>LT negative<br>EQ positive | | <b>DEX</b> (Bit 11) | Decimal exception enable<br>0 set C-bit<br>1 take fault | | <b>I</b> (Bit 15) <b>S</b> (Bit 16) | In dispatcher - set/cleared only by process exchange<br>Save done - set/cleared only by process exchange | C-bit (VI): Set by error conditions in arithmetic operations and by shifts. **L-bit (VI)**: Set by an arithmetic or shift operation except IRS, IRX, DRX. Equal to carry out of the most significant bit (bit 1) of an arithmetic operation. It is valuable for simulating multiple - precision operations and for performing unsigned comparisons following a CAS or a SUB. Condition code bits (VI): The two condition-code bits are designated "EQ" and "LT". EQ is set if and only if the result is zero; if overflow occurs, EQ reflects the state of the result after truncation rather than before. LT reflects the extended sign of the result (before truncation, if overflow), and is set if the result is negative. ## Modals (VI) Processor status is available in another 16-bit register known as the "modals". | E | ٧ | 0 | CURREG | MIO | P | S | MCK | | | |------------|-------------|------------|--------|-------------------------|---------|------|---------|-------|--| | 1 | 2 | 3-8 | 9-11 | 12 | 13 | 14 | 15-16 | | | | E () | Bit 1 | 1) | | Interrupts | enabl | ed | | | | | V ( | Bit : | 2) | | Vectored-i | nterru | pt m | ode | | | | CÙ | RRI | EG (Bits 9 | , | Current re<br>exchange) | egister | set | (set/cl | eared | | | MI | <b>O</b> (E | Bit 12) | | Mapped I/ | O mo | de | | | | | <b>P</b> ( | Bit : | 13) | | Process-ex | chang | e mo | de | | | | <b>S</b> ( | Bit : | 14) | | Segmentat | ion m | ode | | | | | | | Bits 15–16 | 3) | Machine-o | heck | mode | 9 | | | # Note Never attempt to write into the keys or the modals with the STLR instruction. The only valid way to change either the keys or the modals is to use the LPSW instruction, the keys operations OTK and TAK, or the various special-case instructions designed to manipulate specific bits of the status. Furthermore, even LPSW should not be used to alter the indispatcher and save-done bits of the keys or the register-set bits of the modals. # INSTRUCTION FORMATS # GENERIC (SRVI) The entire instruction word is an opcode. Bits 3-6 are always zero # SHIFT (SR) | ОР | SHIF | FT-NO | | |-----------------------|------------------|------------------------------------------------------|----| | 1 | 10 11 | 16 | | | <b>OP</b> (Bits 1–10) | Opcode - Bits 3– | -6 are always zero | | | SHIFT-NO (Bits 11–16) | | ent of the number of places to beans shift 63 places | ie | # I/O (SR) | CLASS | 1 1 0 | 0 | F | UNCTION | DE | VICE | | |----------------|------------|------|---|-------------|----------|-------------|--------| | 1 2 | 3 | 6 | 7 | 10 | 11 | 16 | | | CLASS (B | its 1–2) | | | Type of I/O | instruc | tion | | | | | | | 00 Contro | ol | | | | | | | | 01 Sense | | | | | | | | | 10 Input | | | | | | | | | 11 Outpu | ıt | | | | Bits 3-6 | | | | 1100 | | | | | <b>FUNCTIO</b> | N (Bits 7 | -10) | | Subdivision | of class | . Device de | penden | | DEVICE ( | Bits 11–16 | B) | | Device type | | | 1 | ## DECIMAL (VI) # CHARACTER (VI) | | ОР | |-----------------------|------------------------------------------------------------------| | 1 | 16 | | <b>OP</b> (Bits 1–16) | Opcode. This instruction uses previously set up field registers. | ## GENERIC AP (VI) **OP** (Bits 1–16) 17 Opcode **WORDNO** (Bits 17-32) Word number offset from procedure base register. 32 # Memory reference instruction format (SRV) See Effective Addressing Formation in Section 10 - Memory Reference Concepts. # INSTRUCTION FORMATS — I-MODE #### Purpose of I-Mode The I-Mode instruction formats provide a 32-bit general register environment, particularly useful for: - Heavy floating point calculations. - Heavy long integer calculations. - Extensive complex computations with intermediate results. #### **Features** - V-mode data types are a subset of I-mode data types, so no conversion is needed. - The user visible V-mode register set is a subset of the I mode registers, so data can be passed in a common subset. - The procedure call instruction automatically switches the addressing mode on a subroutine basis so the programmer can organize programs to use the best of V or I mode. - The generic format instructions have the same opcode and same function in V and I mode. - The memory reference format permits convenient specification of target registers in addition to the base, index, and displacement fields. - All forms of indexing and indirection are supported. - The same memory reference instruction can include register to register, register to memory and immediate data forms-special instructions are not required. - The 16-bit format (register and non register generic) is included for additional efficiency. In addition, the register to register and floating register-source addressing formats do not use the second 16-bit part (bits 17-32) of the instruction word. #### **FORMATS** # Non-register generic These instructions are a subset of the V-mode generics and are processed the same way. #### Register generic These instructions operate on the specified register, which may be general, field, or floating register. This class includes the branch instructions, where the branch address, in the second word, is a 16-bit procedure base displacement. #### Memory reference There are three types of memory reference instructions: MRNR-memory reference non register: MRGR-memory reference general register: MRFR-memory reference floating register: Index registers: General registers 1 to 7 may be used as index register; 0 means no indexing. **Register to register**: No indexing or indirection may be specified and the address field insert may be an absolute value: - 1. 0 or 1 if the instruction format is MRFR, or - 2. 0-7 if the instruction format is MRGR | Table 9-1. A | ddress | Format | ion Special Case Selection | |--------------|---------------|---------------------|---------------------------------------| | AD | S | В | Effective Address/Instruction Type | | 3 | >0 | | (D+B)*+S (indirect, post-index) | | 3 | 0 | <u></u> | (D+B)* (indirect) | | 2 | >0 | ) . <del></del> - 1 | (D+B+S)* (pre-index, indirect) | | 2 | 0 | | (D+B)*(indirect) | | 1 | >0 | <del></del> | D+B+S (indexed) | | 1 | 0 | | D+B (direct) | | 0 | $\geqslant 0$ | 0 | REG-REG (S specifies source register) | | 0 | 0 | 1 | Immediate Type 1 | | 0 | >0 | 1 | Immediate Type 2 | | 0 | 0 | 2 | Immediate Type 3 | | 0 | 1 | 2 | Floating Reg Source (FRO) | | 0 | 2 | 2 | Undefined (will not generate UII) | | 0 | 3 | 2 | Floating Reg source (FR1) | | 0 | 4-7 | 2 | Undefined (will not generated UII) | | 0 | _ | 3 | Undefined (will not generate UII) | | | | | | | Field | Mnemo | nics: | | | | OP | Opco | ode | | | R | | ination register | | | AD | Addı | ress computation code | | | S | Sour | ce register | | | В | | register | | | FR | | ting register | Immediate: There are three immediate data formats: # Immediate type 1 1 8 9 16 Sign extend full word general register instruction. Requires a 32-bit literal (with L suffix). Bit 17, the low order sign bit, is extended through the high order 16 bits. ## Immediate type 3 Floating point register instruction (both single and double precision) requires floating point literal. The fractional part is truncated to eight bits, stored in the instruction. # Memory reference concepts - SRV #### BACKGROUND CONCEPTS Memory is addressed as a set of continuous word locations. The number of words that can be addressed by an instruction, and the way in which the address is calculated depends on the current addressing mode of the machine and the location of the address relative to the instruction. In turn, the addressing modes of the machine differ in the size of the instruction word, the number of bits allotted to the provisional address displacement, and the number and meaning of the bits allotted to the operation code. To reduce the number of memory references, designers wish to do as much as possible in one word. For example, in the S and R addressing modes, a one word memory reference instruction has nine bits (512 words) of direct addressability, four bits for operation codes, one bit for indirection, one bit for indexing, and one bit to control out-of-range addresses. Within each addressing mode, there are the following tradeoffs: - 1. Size of program address space - 2. Levels of indirection - 3. Levels of indexing - 4. Whether indexing is performed before or after indirection - 5. Number of operation codes available Through the discussion of the S, R, and V addressing modes, we shall show how these variables are defined. #### Memory organization **Sectors:** (S-Mode and R-Mode when S=0). A sector is a contiguous group of 512 words. S-Mode memory reference instructions have nine bits (D field) of addressability to any location in a sector and one bit, the S-bit, to specify Sector 0 (S=0) or the current sector (S=1). D and S together give 10 bits, or 1024 words, of direct addressability. **Relative reach:** (R-Mode and V-Mode when S=1). When S=1 the D field is interpreted as a signed number in the range -255 to +256. When D $\leq$ 240 (R-Mode), or D $\leq$ 224 (V-Mode), the number is treated as a code, not as a displacement. When -240<D<256 (R-Mode) or -224<D <256 (V-Mode), the address is relative to the program counter. **Segmentation:** (V-Mode and I-Mode). See the System Architecture Reference Guide for a discussion of segmentation. #### Effective address formation Each memory reference instruction calculates an effective address. This calculation and its results vary depending on addressing mode and instruction format; variables include preand post-indexing, indirection, and base registers. For maximum clarity, we discuss the classes by format types and present addressing mode flowcharts. Both the format discussions and the addressing mode flowcharts are cross referenced to each other. Table 10-1 summarizes the format classes and gives the addressing modes where they are used. **Indexing:** In general, if the X-bit of the instruction is set, the contents of the index register are added to the D-field. If the indirect bit is set, the address mode and D-field determine whether indexing occurs before or after indirection. The result is truncated to the number of bits permitted by the addressing modes, and the high order bits are cleared. In V-Mode, there are two index registers, X and Y. The displacement field determines which to use and how to use it. #### Note The index register may be preset by the program to any value between -32768 and +32767. **Indirection:** In general, if the I-bit is set, the D-field plus index, if any, is an intermediate address. The indirect address word at that location may, depending on the address mode, also contain X and I bits. The specific addressing mode discussion gives the details. Address truncation (S R): After effective address formation is complete, the resulting address is truncated to the number of bits appropriate to the addressing mode in effect: | Mode | Addressing Bits | Size of Addressable Memory | |------|-----------------|----------------------------| | 16S | 14 | 16K | | 32S | 15 | 32K | | 32R | 15 | 32K | | 64R | 16 | 64K | Since the higher order bits of the address are zeroes, an address cannot be formed that addresses a memory location beyond the range of the current addressing mode. However, it is possible for an executing program to increment the program counter out of the current range (instead of overflowing to zero). | Table 10-1. Memory Refer | ence Instruction | Form | at | | | |--------------------------------------|------------------|-------------------|----------------|--------|------| | Туре | No. Words | $\mathbf{S}^{_1}$ | $\mathbf{D}^2$ | $CB^3$ | Mode | | Basic | 1 | 0 | 0 - '777 | | SR | | Sector Relative | 1 | 1 | 0 - '777 | | S | | Procedure Relative | 1 | 1 | -241 to +255 | | R | | | | | -224 to +255 | | V | | Stack Postincrement/<br>Predecrement | 1 | 1 | -256 to -241 | 2,3 | R | | Base Register<br>Relative | 1 | 0 | 0 - '777 | | V | | Long Reach | 2 | 1 | -256 to $-241$ | 0,2 | R | | Stack Relative | 2 | 1 | -256 to $-241$ | 1,3 | R | | Base Registers | 2 | 1 | -256 to $-224$ | | V | - 1. **Sector bit (S)**. Bit 7 in both one- and two-word memory reference instructions. The meaning varies, depending on the addressing mode, but in general is used to control out-of-range addresses. - 2. **Displacement field (D)**. Bits 8–16 in the instruction word. Bit 8 is sign bit except in Basic, Sector Relative, and Base Register types of instruction. - 3. Class bits (CB). Bits 15 and 16 of the R mode two-word instructions distinguish between Long Reach and Stack Relative instruction types. ## Instruction range The range that an instruction can directly address is called its addressing range. The assembler and the loader analyze the assembler statement and set up both in-range and out-of-range addresses. In the discussion below we shall examine the sectored and relative address ranges and how they are set up prior to execution. The segmentation concepts and address ranges are discussed in the System Architecture Reference Guide. **Sectored**: In S-mode, the memory reference instructions can address any location in sector 0 or in the sector of the instruction. When S=1, the nine bit displacement field is a location in the current sector. When S=0, the nine bit displacement is in sector 0. The software uses the S-bit to control out-of-range addresses in the following manner: the assembler does a preliminary analysis of the relation of the displacement field (expression or symbol) to the instruction location, and passes this information to the loader, which sets up the final instruction for execution. The loader puts the object code received from the assembler together with any other required routines (such as subroutines), resolves external linkages and sets up sector 0, the communication and linkage area. Sector 0 can also be directly addressed by the program, a useful feature for handling common data fields. **Relative**: In R-mode when S=1, the D field is interpreted as a signed number in the range -226 to +255. When the two high order bits are one (D $\leq$ 240) the number is treated as a code, not as a displacement. When -240 < D < 255 the address is relative to the program counter. The loader analyzes the displacement field and if the effective address will be out of relative range (-240 to +255) sets S=0, I=1, and the displacement field to point to the address word in sector zero. Thus, in 64R, if the address is out of range, no indirection is possible because the loader uses the instruction word indirect bit. | Assembler<br>Notation | | Location of ADDR | | |-----------------------|--------------------------------------------------------------------------------|--------------------------------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | | Sector 0 | Same Sector | Other | | LDA ADDR | S=0<br>I=0<br>D=location in sector 0. | <b>S</b> =1 <b>I</b> =0 | <b>S</b> =0 <b>I</b> =1 | | | B-iodation in sector of | D=displacement in same sector. | D=first available link in sector 0. At that location an indirect word is constructed with I=0. pointing at ADDR with a full 14 (16S) or 15 (32S. 32R) or 16 (64R) bit indirect address. | | LDA ADDR,* | <b>S</b> =0<br><b>I</b> =1 | S=1<br>I=1 | <b>S</b> =0 <b>I</b> =1 | | | <b>D</b> =Location in sector 0 which contains a pointer defined by the program | <b>D</b> =Location in same sector. It must contain pointer defined by program. | D=first available link in sector 0. At that location an indirect word is constructed with I=1 and a full 14 (16S) or 15 (32S. 32SR) bit indirect pointer to ADDR. Not permitted in 64R. | 10 - 3 # MEMORY REFERENCE INSTRUCTION FORMATS BASIC (one word, S-bit=0) 16S, 32S, 32R, 64R | ı | X | | OP | | S | | D | | |---|---------------|----------|----|-----|--------|-------------|---------|----| | 1 | 2 | 3 | | 6 | 7 | 8 | | 16 | | | I (Bit | 1) | | Inc | lirect | Bit | | | | | X (Bit | 2) | | Inc | lex Bi | t | | | | | OP (B | its 3-6) | | Op | code | | | | | | <b>S</b> (Bit | 7) | | Se | ctor B | it = 0 | | | | | D (Bit | ts 8-16) | | Dis | splace | ement in se | ector 0 | | The D-field is a displacement in sector 0. The effective address is equal to bits 8-16 of the instruction, with bits 0-7 equal to zero. Indexing and indirection are a function of the I and X bits and the addressing mode. | Mode | | X | S | | EA | Type | |-------------|--------------|------------|--------|---------|------------|--------------------------| | 16S | 0 | 0 | 0 0 to | 777 | $0 \mid D$ | Direct | | | 0 | 1 | | 777 | 0 D+X | Indexed | | | 1 | 0 | 0 0 to | 777 | I(0 D) | Indirect | | | | .1 | 0 0 to | 777 | | Indirect,<br>preindexed | | 32S, 32R, 6 | <b>64R</b> 0 | 0.5 | 0 0 to | 777 | 0 D | Direct | | | 0 | 1 1 | 0 0 to | 777 | 0 D+X | Indexed | | | 1 | 0 | 0 0 to | `777 | I(0 D) | Indirect | | | | 1 | 0 0 to | | I(0 D+X) | Indirect,<br>preindexed | | | | 110<br>200 | 0 '100 | to '777 | I(0 D)+X | Indirect,<br>postindexed | # SECTOR RELATIVE (One word, S-bit=1) 16S, 32S The D-field is a displacement in the current sector. The effective address is formed by concatinating the D-field bits with the higher order bits of the program counter (P). Indexing and indirection are a function of the I and X bits and the addressing mode. Bits 1 and 2 (16S) or 1 (32S) of the final effective address are cleared. In effect, the program counter gives the sector number and the D-field, the location within the sector. | Addressing<br>Mode | I X | <b>S D</b> | <b>EA</b> | Туре | |--------------------|-----|-------------|--------------|--------------------------| | 16S | 0 0 | 1 0 to '777 | P D | Direct | | | 0 1 | 1 0 to '777 | P D+X | Indexed | | | 1 0 | 1 0 to '777 | I(P D) | Indirect | | | 1 1 | 1 0 to '777 | I(P D+X) | Indirect,<br>preindexed | | 32S | 0 0 | 1 0 to '777 | PD | Direct | | | 0 1 | 1 0 to '777 | $P \mid D+X$ | Indexed | | | 1 0 | 1 0 to '777 | I(P D) | Indirect | | | 1 1 | 1 0 to '777 | I(P D) +X | Indirect,<br>postindexed | # PROCEDURE RELATIVE (One word, S-bit=1) 32R, 64R, 64V | ı | х | | OP | | S | D | | | | | |---|----------------------|-----------|----|-----------------------------------------------------------------|--------|------------|----|--|--|--| | 1 | 2 | 3 | | 6 | 7 | 8 | 16 | | | | | | I (Bit | 1) | | Inc | direct | Bit | | | | | | | X (Bi | t 2) | | Index Bit | | | | | | | | | OP (E | 3its 3-6) | | Ор | code | | | | | | | | <b>S</b> (Bit | 7) | | Se | ctor B | it=1 | | | | | | | <b>D</b> (Bits 8-16) | | | Location relative to the program counter $64V = -224$ to $+255$ | | | | | | | | | | | | | | 40 to +255 | | | | | Addressing is relative to the current program counter value, which is the current instruction location plus 1. The effective address is formed by adding the value of the D-field to the updated program counter value (P). Indirection and indexing are a function of the I and X bits and the addressing mode. | Addressing<br>Mode | I | X | s | D | EA | Type | |--------------------|---|---|---|----------------|----------|--------------------------| | 32R, 64R | 0 | 0 | 1 | - 240 to +255 | P+D | Direct | | | 0 | 1 | 1 | - 240 to +255 | P+D+X | Indexed | | | 1 | 0 | 1 | -240 to +255 | I(P+D) | Indirect | | | 1 | 1 | 1 | - 240 to +255 | I(P+D)+X | Indirect,<br>postindexed | | 64V | 0 | 0 | 1 | - 224 to +255 | P+D | Direct | | | 0 | 1 | 1 | -224 to $+255$ | P+D+X | Indexed | | | 1 | 0 | 1 | - 224 to +255 | I(P+D) | Indirect | | | 1 | 1 | 1 | - 224 to +255 | I(P+D)+X | Indirect,<br>postindexed | 1 March, 1979 10-5 FDR 3059 # STACK PREDECREMENT, POSTINCREMENT (One word, S-bit=1) 32R, 64R | ı | х | ОР | 11000 | | XX | СВ | | | | | | |---|--------------|-------------|------------------|----|-------|-------|------------------|--|--|--|--| | 1 | 2 | 3 | 6 7 | 12 | 13 14 | 15 16 | | | | | | | | I (Bit | : 1) | Indirect Bit | | | | | | | | | | | X (Bi | • | Index Bit | | | | | | | | | | | OP ( | Bits 3-6) | Opcode | | | | | | | | | | | Bits 7 | 7–12 | 110000 | | | | | | | | | | | <b>XX</b> () | Bits 13–14) | Opcode extension | | | | Opcode extension | | | | | | | <b>CB</b> (] | Bits 15–16) | Class Bits | | | | | | | | | These classes use the stack pointer (SP) as the address displacement, and perform an auxiliary postincrement or predecrement of the pointer. Instructions using these address methods are always one-word instructions. | Addressing<br>Mode | I | X | S | СВ | EA | Type | |--------------------|---|---|---|----|-----------|---------------------------------------------| | 32R, 64R | 0 | 0 | 1 | 2 | SP | Postincrement | | | 0 | 1 | 1 | 2 | I(SP)+X | Postincrement, indirect, post-indexed | | | 1 | 0 | 1 | 2 | I(SP) | Postincrement indirect | | | 0 | 0 | 1 | 3 | SP-1 | Predecrement | | | 0 | 1 | 1 | 3 | I(SP-1)+X | Predecrement,<br>indirect, post-<br>indexed | | | 1 | 0 | 1 | 3 | I(SP-1) | Predecrement indirect | #### Note If a fault occurs during the execution of these classes. anomalous behavior can result. # BASE REGISTER RELATIVE (One word, S-bit=0) 64V | ı | Х | OP | | S | | D | |---|--------|----------|---------------------------------------------|--------|-----|----| | 1 | 2 | 3 | 6 | 7 | 8 | 16 | | | I (Bit | 1) | Inc | direct | Bit | | | | X (Bit | 2) | Inc | dex B | it | | | | OP (B | its 3-6) | Op | code | | | | | S (Bit | 7) | Sector Bit=0 | | | | | | D (Bit | ts 8-16) | Location relative to selected base register | | | | This format provides 64V with one word based memory reference instructions, using the D-field to encode both base and displacement. All indirection will be through 16-bit pointers in the procedure segment and the final effective address of indirect instructions will be in the procedure segment. | co1 | 66 | 1 1 | 1 1 | 1 . • | | |------|-----------|---------|-------|--------|-----| | Tha | effective | addrage | Calcu | lation | 10' | | 1110 | CIICCIIVE | auurcss | carcu | ialion | 10. | | I | X S | D | Address | Туре | |---|-----|--------------------|----------------------|-------------| | 0 | 0 0 | 0-'7 | register location | Direct | | | | '10–'377 | SB+D | | | | | '400–'777 | LB+D | , | | 0 | 1 0 | 0-'377 | if $D+X<'10$ then | Indexed | | | | | EA=register location | | | | | 1400 1555 | else SB+D+X | · | | | | '400–'777 | LB+D+X | · _ | | 1 | 0 0 | 0-'7 | I(REG) | Indirect | | | | '10–'777 | I(PB D) | | | 1 | 1 0 | 0-'77 | I[PB D+X] | Indirect | | | | | | preindexed | | 1 | 1 0 | '100–'777 | I[PB D] + X | Indirect | | | | | | postindexed | | | PB | Procedure base r | egister | | | | LB | Link base register | <b>r</b> ia da Maria | | | | SB | Stack base registe | er jakaji | | | | X | Index register | | | | | D | Displacement fiel | ld 🦎 | | | | REG | R-Mode registers | , i.e., A,B,X, etc. | 1 | # LONG REACH (Two word, S-bit=1) 32R, 64R | l | X OP | | OP | 11000 | | | XX | СВ | | |----|--------|--------------|----|------------------|----|----|-------|-------|--| | 1 | 2 | 3 | 6 | 7 | | 12 | 13 14 | 15 16 | | | | | | | Α | | | | | | | 17 | | | | | | | | 32 | | | | I (Bit | 1) | In | direct Bi | it | | | | | | | X (Bi | t 2) | In | dex Bit | | | | | | | | OP (E | 3its 3-6) | O | pcode | | | | | | | | Bits 7 | <b>'</b> -12 | 11 | 0000 | | | | | | | | XX (E | 3its 13-14) | O | Opcode extension | | | | | | | | , | its 15–16) | • | ass Bits | | | | | | | | | ts 17–32) | Ac | Address word | | | | | | The 16-bit address word in the location following the instruction plus the I and X bits in the instruction combine in effective address calculation. The direct instruction reach is extended to 32K words (32R) or 64K words (64R), since the address is in the word following the instruction. In 32R, bit 1 is zero. In 64R, all 16 bits are used. | Addressing<br>Mode | I | X | s | СВ | EA | Туре | |--------------------|---|---|---|----|----------|-----------------------| | 32R, 64R | 0 | 0 | 1 | 0 | A | Direct | | | 0 | 1 | 1 | 0 | A+X | Indexed | | | 1 | 0 | 1 | 0 | I(A) | Indirect | | | 1 | 1 | 1 | 0 | I(A+X) | Indirect, preindexed | | | 1 | 1 | 1 | 2 | I(A) + X | Indirect. postindexed | # STACK RELATIVE (Two Word, S-bit = 1) 32R,64R | ı | X | | OP | | 11000 | XX | СВ | |---|---|---|----|---|-------|-------|-------| | 1 | 2 | 3 | 6 | 7 | 12 | 13 14 | 15 16 | Α 32 17 Indirect Bit **I** (Bit 1) Index Bit **X** (Bit 2) Opcode **OP** (Bits 3–6) 110000 Bits 7-12 Opcode extension **XX** (Bits 13-14) Class Bits **CB** (Bits 15–16) Address word **A** (Bits 17–32) This class is identical to two-word long reach except that the contents of the stack pointer (SP) are added to the address word following the instruction word during the initial effective address calculation. Indexing and indirection take place under control of the I and X bits and the addressing mode. | Addressing | | | | | | | |------------|---|---|--------------|-----|-----------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | Mode | I | X | $\mathbf{S}$ | CB | EA | Type : Name of the state | | 32R, 64R | 0 | 0 | 1 - 1 | 1 | A+SP | Direct | | | 0 | 1 | 1 | 1 | A+SP+X | Indexed | | | 1 | 0 | 1 | 1 1 | I(A+SP) | Indirect | | | 1 | 1 | 1 | 1 | I(A+SP+X) | Indirect, preindexed | | | 1 | 1 | 1 | 3 | I(A+SP)+X | Indirect, postindexed | ## TWO WORD MEMORY REFERENCE 64V | ı | х | OP | | 11000 | Y | | XX | | BR | |---|----------|-------|---|------------|-----|----|----|----|-------| | 1 | 2 | 3 — 6 | 7 | 11 | 12 | 13 | | 14 | 15-16 | | | | | | Α | | | | | | | | I (Bit 1 | 1) | | Indirect b | oit | | | | | X bit **X** (Bit 2) Opcode **OP** (Bit 3-6) 110000 Bits 7-12 Y bit **Y** (Bit 12) Opcode extension **XX** (Bits 13–14) Base register: 00=PB, 01=SB, 10=LB, 11=XB **BR** (Bits 15–16) 16-bit word displacement relative to the base selected **A** (Bits 17–32) by the BR bits I, X, Y and BR combine to give all 32 possible address combinations: - Direct - Indexed by X - Indexed by Y - Indirect - · Preindexed by X - Preindexed by Y - Postindexed by X - Postindexed by Y All indirect words are either 32 or 48 bit format and the final effective address is always a memory address (never a register). Table 10-3 shows all possible combinations. | 1 | X | Y | BR | Effective Address | Meaning | |--------------------|------|----------------------|-----------------|-------------------|----------------------------------------------------------------------------------------------------------------------------| | 0 | 0 | 0 | 0 | PBD | | | | | | 1 1 | SB+D | Direct | | | | | 2 | LB+D | | | | 6648 | | 3 | XB+D | | | 0 | 0 | 1 | 0 | PB D+Y | | | | | | 1 | SB+D+Y | Indexed by Y | | | | ប៉ីនាស្ត្រ<br>ខណៈស្ត | 2 | LB+D+Y | (3) (1) (1) (2) (2) (2) (2) (2) (2) (3) (3) (3) (4) (4) (4) (4) (5) (6) (6) (6) (6) (7) (7) (7) (7) (7) (7) (7) (7) (7) (7 | | 2 2 2 2<br>0 2 2 1 | | | 3 | XB+D+Y | | | 0 | 1 | 0 | 0 | PB D+X | | | | | | 1 | SB+D+X | Indexed by X | | | | | 2 | LB+D+X | | | | | | 3 | XB+D+X | | | 0. | 1 | -1 | 0 | I(PBD) | | | | | | 1 | I(SB+D) | Indirect | | | | | 2 | I(LB+D) | | | | | | 3 | I(XB+D) | | | 1 | 0 | 0 | 0 | I(PB D+Y) | | | | | | 1 | I(SB+D+Y) | Pre-indexed by Y | | | | | 2 | I(LB+D+Y) | | | | | | 3 | I(XB+D+Y) | | | 1 , | 0 | 1 | 0 | I(PB D)+Y | | | | | | 1 | I(SB+D)+Y | Post-indexed by Y | | | | | $2^{^{\prime}}$ | I(LB+D)+Y | | | | | | 3 | I(XB+D)+Y | | | 1 | 1 | 0 | 0 | I(PB D+X) | | | | | | 1 | I(SB+D+X) | Pre-indexed by X | | | | | 2 | I(LB+D+X) | | | | | | 3 | I(XB+D+X) | | | 1 | 1 | 1 | 0 | I(PB D) + X | | | | | | 1 | I(SB+D)+X | Post-indexed by X | | | | | ,2 | I(LB+D)+X | • | | | | | 3 | I(XB+D)+X | | 1 March, 1979 FDR 3059 # ADDRESSING MODE SUMMARIES AND FLOW CHARTS # 16S summary Address length: 14 bits; 16K word address space Format: **Indexing**: Multiple levels. In an indirect word, the index calculation is done before the indirection. Indirection: Multiple levels. | | | | | | Assembler | | | | |------|-------|-------|-----------|-----------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------|-------------------------|--|--| | I | X | S | D | EA | Notation | Туре | | | | 0 | 0 | 0 | 0 to '777 | 0 D | LDA ADDR | Direct | | | | 0 | 1 | 0 | 0 to '777 | 0 D+X | LDA ADDR,1 | Indexed | | | | 1 | 0 | 0 | 0 to '777 | I(0 D) | LDA ADDR,* | Indirect | | | | 1 | 1 | 0 | 0 to '777 | I(0 D+X) | LDA ADDR,1* | Indirect, | | | | | | | | | | preindexed | | | | 0 | 0 | 1 | 0 to '777 | P D | LDA ADDR | Direct | | | | 0 | 1 1 | 1 | 0 to '777 | P D+X | LDA ADDR,1 | Indexed | | | | 1 | 0 | 1 | 0 to '777 | I(P D) | LDA ADDR,* | Indirect | | | | 1 | 1 | 1 | 0 to '777 | I(P D+X) | LDA ADDR,1* | Indirect,<br>preindexed | | | | P | | | | Contents of progr<br>(pointing at instr | am counter prior to i uction). | nstruction fetch | | | | 0 D | | | | Displacement int<br>address (bits 3-8) | Displacement into sector 0. Sector bits of effective address (bits 3-8) are zero. | | | | | P D | | | | tion of sector bi | Displacement in current sector formed by concatena-<br>tion of sector bits from program counter with dis-<br>placement field in instruction word. | | | | | X | | | | Contents of index register. | | | | | | I(e: | kpres | sion) | | | Treat the effective address as indirect address. | | | | | AD | DR | | | Location address | Location addressed by the LDA. | | | | #### Note If D is 0-7 and S=0, the effective address is a register. # 32S (Includes 32R when S=0) summary Address length: 15 bits, 32K word address space Format: **Indexing:** One level. The 15-bit indirect address word eliminates the X bit. Done after all indirection is complete, except for the special case shown in the table below. Indirection: Multiple levels. | 64 13 A<br>44 F S<br>21 A S<br>28 S | | | | | | Assembler | のである。 日本の (日本の ) | | | | |-------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------|------|-------|------------|------------------------|---------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--| | 10 15 P | I | X | S | | EA | Notation | Туре | | | | | 7. K.S.S. | 0 | 0 | 0 | 0 to 777 | 0 D | LDA ADDR | Direct | | | | | 14.00 | 0 | 1 | 0 | 0 to '777 | 0 D+X | LDA ADDR,1 | Indexed | | | | | 1.0 | 1 | 0 | 0 | 0 to '777 | I (0 D) | LDA ADDR,* | Indirect | | | | | 1. 1 4.<br>1. 1 4.<br>1. 1 4. | 1 | 1 | 0 | 0 to 77 | I(0 D+X) | LDA ADDR.1* | Indirect,<br>preindexed | | | | | | 1 | 1 | 0 | 100 to 777 | I(0 D)+X | LDA ADDR,*1 | Indirect<br>postindexed | | | | | | 0 , | 0 | 1 | 0 to '777 | PD | LDA ADDR | Direct | | | | | | 0 | 1 | 1 | 0 to 7777 | P D+X | LDA ADDR,1 | Indexed | | | | | | 1 | 0 | 1 | 0 to '777 | I(P D) | LDA ADDR,* | Indirect | | | | | | 1 | 1 | 1 | 0 to '777 | I(P D) + X | LDA ADDR,1* | Indirect<br>postindexed | | | | | | P | | | | | of program counter prior t at instruction). | o instruction fetch | | | | | | 0 D | | | | Displacer<br>address ( | nent into sector 0. Sector<br>bits 3-8) are zero. | r bits of effective | | | | | | PID Displacement in current sector formed by conc<br>tion of sector bits from program counter with<br>placement field in instruction word. | | | | | | | | | | | | X | | | | Contents | Contents of index register. | | | | | | | I(ex | pres | sion) | | Treat the | Treat the effective address as indirect address. | | | | | | | ADI | OR | | | Location | addressed by the LDA. | | | | | #### Note If D is 0-'7 and S=0, the effective address is a register. ## 32R summary Address length: 15 bits; 32K word address space #### Format: Indexing: One level. Indirection: Multiple levels. | | | | | | | Assembler | | |---|---|---|----------|----------------|--------------|-------------|--------------------------------------------| | 1 | X | S | CB | D | EA | Notation | Type | | 0 | 0 | 0 | · . | 0 to '777 | 0 D | LDA ADDR | Direct | | 0 | 1 | 0 | | 0 to '777 | 0 D+X | LDA ADDR,1 | Indexed | | 1 | 0 | 0 | | 0 to '777 | I(0 D) | LDA ADDR,* | Indirect | | 1 | 1 | 0 | | 0 to '77 | $I\{0 D+X\}$ | LDA ADDR,1* | Indirect,<br>preindexed | | 1 | 1 | 0 | | '100 to '777 | I(0 D)+X | LDA ADDR,*1 | Indirect,<br>postindexed | | 0 | 0 | 1 | | -240 to +255 | P+D | LDA ADDR | Direct | | 0 | 1 | 1 | | -240 to +255 | P+D+X | LDA ADDR,1 | Indexed | | 1 | 0 | 1 | <u>-</u> | -240 to +255 | I(P+D) | LDA ADDR,* | Indirect | | 1 | 1 | 1 | | -240 to +255 | I(P+D)+X | LDA ADDR,*1 | Indirect,<br>postindexed | | 0 | 0 | 1 | 2 | | SP | LDA @+ | Postincrement | | 0 | 1 | 1 | 2 | | I(SP)+X | LDA @+,*1 | Postincrement,<br>indirect,<br>postindexed | | 1 | 0 | 1 | 2 | | I(SP) | LDA @+,* | Postincrement, indirect | | 0 | 0 | 1 | 3 | <del></del> | SP-1 | LDA -@ | Predecrement | | 0 | 1 | 1 | 3 | _ | I(SP-1)+X | LDA -@,*1 | Predecrement,<br>indirect,<br>postindexed | | 1 | 0 | 1 | 3 | <del>-</del> , | I(SP-1) | LDA -@,* | Predecrement,<br>indirect | | | -, : | 11.5. | | | | | | | | | |-----|------|------------|----------------------------------------------------------|-------|----|-----------------------------------------------------------------------------------|-------------------------------------|--------------------------------------------|--|--| | | 0 | 0 | 1 | 0 | | | LDA% ADDR | Direct,<br>long reach | | | | | 0 | 1 | 1 | 0 | | A+X | LDA% ADDR,X | Indexed,<br>long reach | | | | 667 | 1 | 0 | 1 | 0 | | I(A) | LDA% ADDR,* | Indirect,<br>long reach | | | | | 1 | 1 | 1 | 2 | | I(A+X) | LDA% ADDR,X* | Indirect,<br>preindexed<br>long reach | | | | | 1 | 3 <b>1</b> | 90 <b>1</b> 0<br>8 5<br>2 8 5<br>2 8 5<br>2 8 5<br>4 8 6 | 2 | | I(A)+X | LDA% ADDR,*X | Indirect,<br>postindexed<br>long reach | | | | | 0 | 0 | 1 | 1 | | A+SP | LDA @+ADDR | Direct, stack<br>relative | | | | | 0 | 1 | 1 | 1 | | A+SP+X | LDA @+ADDR,X | Indexed, stack<br>relative | | | | | 1 | 0 | 1 | 1 | | I(A+SP) | LDA @+ADDR,* | Indirect, stack relative | | | | | 1.00 | | | | | I(A+SP+X) | LDA @+ADDR,X* | Indirect,<br>preindexed,<br>stack relative | | | | | 1 | | | | | I(A+SP)+X | LDA @+ADDR,*X | Indirect,<br>postindexed,<br>relative | | | | | | | | | | Contents of pro<br>(pointing at ins | gram counter prior to<br>truction). | o instruction fetch | | | | | | | ) D | | | Displacement into sector 0. Sector bits of effective address (bits 3-8) are zero. | | | | | | | | 7 | ζ. | | | Contents of index register. | | | | | | | | I | (expr | essio | n) | Treat the effective address as indirect address. | | | | | | | 1 | 1 | ADDR | | | Location addressed by the LDA. | | | | | 10-17 ## 64R summary Address length: 16 bits; 64K word address space #### Format: Indexing: One level.Indirection: One level. | | | | | | | Assembler | | |---|---|---|--------------|----------------|------------|-------------|--------------------------------------------| | I | X | S | CB | D | EA | Notation | Type | | 0 | 0 | 0 | <u> </u> | 0 to '777 | 0D | LDA ADDR | Direct | | 0 | 1 | 0 | | 0 to '777 | 0,D+X | LDA ADDR,1 | Indexed | | 1 | 0 | 0 | + | 0 to '777 | I(0 D) | LDA ADDR,* | Indirect | | 1 | 1 | 0 | · — | 0 to '77 | I(0 D+X) | LDA ADDR,1* | Indirect,<br>preindexed | | 1 | 1 | 0 | | '100 to '777 | I(0 D) + X | LDA ADDR*1 | Indirect,<br>postindexed | | 0 | 0 | 1 | | -240 to +255 | P+D | LDA ADDR | Direct | | 0 | 1 | 1 | | -240 to $+255$ | P+D+X | LDA ADDR,1 | Indexed | | 1 | 0 | 1 | | -240 to $+255$ | I(P+D) | LDA ADDR,* | Indirect | | 1 | 1 | 1 | numero promi | -240 to +255 | I(P+D)+X | LDA ADDR,*1 | Indirect.<br>postindexed | | 0 | 0 | 1 | 2 | | SP | LDA @+ | Postincrement | | 0 | 1 | 1 | 2 | _ | I(SP)+X | LDA @+,*1 | Postincrement.<br>indirect,<br>postindexed | | 1 | 0 | 1 | 2 | | I(SP) | LDA @+,* | Postincrement.<br>indirect | | 0 | 0 | 1 | 3 | | SP-1 | LDA -@ | Predecrement | | 0 | 1 | 1 | 3 | | I(SP-1)+X | LDA -@,*1 | Predecrement<br>indirect.<br>postindexed | | 1 | 0 | 1 | 3 | <del>-</del> | I(SP-1) | LDA -@,* | Predecrement, indirect | | |---|---------------|------------|-----|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------------------------------------------------------------------------|-----------------------------------------------|---------------------------------|--| | 0 | 0 | 1 | 0 | | $\mathbf{A}$ | LDA% ADDR | Direct, | | | | | | | | | | long reach | | | 0 | 1 | 1 | 0 | _ | A+X | LDA% ADDR,X | Indexed,<br>long reach | | | 1 | 0 | 1 | 0 | | I(A) | LDA% ADDR,* | Indirect. | | | | Ü | | | | 1(21) | IBIT 70 TIBBIT, | long reach | | | 1 | 1 | 1 | 0 | | I(A+X) | LDA% ADDR,X* | Indirect, | | | | | | | | | | preindexed<br>long reach | | | 1 | 1 | 1 | 0 | un de la companya de<br>La companya de la co | I(A) + X | LDA% ADDR,*X | Indirect, | | | | | | | | | | postindexed | | | 0 | 0 | 1 | 1 | | A+SP | LDA @+ADDR | long reach<br>Direct, stack | | | | U | | . 1 | | 71+01 | LDN @+NDDR | relative | | | 0 | 1 | 1 | 1 | | A+SP+X | LDA @+ADDR,X | Indexed, stack | | | 1 | 0 | 1 | 1 | | I(A+SP) | LDA @+ADDR,* | relative<br>Indirect, stack | | | 1 | U | 1 | 1 | | I(A+or) | LDA @+ADDR, | relative | | | 1 | 1 | 1 | 1 | | I(A+SP+X) | LDA @+ADDR,X* | Indirect, | | | | | | | | | | preindexed, stack rela-<br>tive | | | | | | | | | | | | | 1 | 1 | 1 | 3 | . <del></del> | I(A+SP)+X | LDA @+ADDR,*X | Indirect, | | | | | | | | | | postindexed, stack relative | | | | | | | | | | | | | | | P | | | | | r after instruction fetch | | | | αID | | | | (pointing at instruction plus 1). | | | | | | 0 D | | | | Displacement into sector 0. Sector bits of effective address (bits 3-8) are zero. | | | | | | X | | | | Contents | of index register. | | | | | I(expression) | | | | | Treat effective address as indirect address. | | | | | | SP<br>ADDR | , | | - | Stack pointer. Location addressed by the LDA. | | | | | | MUDK | • | | Pocation | addressed by the L | 17431 | | ## 64V PROCEDURE RELATIVE (One Word, S=1) Address length: 16 bits; 64K word address space Format: Indexing: One levelIndirection: One level | I X S | D | EA | Type | |--------|-----------------|----------------------|----------------------------------------------------------| | 0 0 1 | -224 to + 255 | P+D | Direct | | 0 1 1 | -224 to +255 | P+D+X | Indexed | | 1 0 1 | -224 to + 255 | I(P+D) | Indirect | | 1 1 1 | -224 to + 255 | I(P+D)+X | Indirect, postindexed | | P | | (pointing at instruc | 의 등 경기 경호하는 이 이 사람들이 되어 가는 것 같아. 그 아이들은 이 그림을 보고 있다면 하다. | | D | | Procedure segmen | t displacement. | | X | | Contents of X regi | ster. | | I[expr | ession] | Treat effective add | dress as indirect address. | # 64V BASE REGISTER RELATIVE (One Word, S=0) Address Length: 3 64K segments Format: Indexing: One level Indirection: One level | I | X | S | D | EA | Туре | | | |---|--------------------|-----|-------------------------------|-------------------------------------------------------------------|--------------------------|--|--| | 0 | 0 | 0 | 0-'7<br>'10-'777<br>'400-'777 | register location<br>SB+D<br>LB+D | Direct | | | | 0 | 1 | 0 | 0-'377<br>'400-'777 | if D+X<'10 then EA = register<br>location * else SB+D+X<br>LB+D+X | Indexed | | | | 1 | 0 | 0 | 0-'7<br>'10-'777 | I(REG)<br>I(PB D) | Indirect | | | | 1 | 1 | 0 | 0-'77 | I (PB D+X) | Indirect,<br>preindexed | | | | 1 | 1 | 0 | '100–'777 | I(PB D)+X | Indirect,<br>postindexed | | | | | ] | REG | | R-mode registers, i.e., A, B, X | , etc. | | | | | 1 | PB | | Procedure base register. | | | | | | 1 | LB | | Link base register. | | | | | | ( | SB | | Stack base register. | | | | | | $oldsymbol{X}$ | | | Index register. | | | | | | D<br>I(expression) | | | Displacement field. Treat effective address as indirect address. | | | | | | | | | | | | | | | , | • | | This is called an address trap. | | | | ## 64V TWO WORD MEMORY REFERENCE Address length: 28 bits; 4096 64K segments Format: Indexing: X and Y Indirection: 48 bit word | I | $\mathbf{X}$ | Y | BR | Effective Address | Meaning | |---|--------------|---|-----|-------------------|-------------------| | 0 | 0 | 0 | 0 | PB D | | | | | | 1 | SB+D | Direct | | | | | 2 | LB+D | | | | | | 3 | XB+D | | | 0 | 0 | 1 | 0 . | PB D+Y | | | | | | 1 | SB+D+Y | Indexed by Y | | | | | 2 | LB+D+Y | | | | | | 3 | XB+D+Y | | | 0 | 1 | 0 | 0 | PB D+X | | | | | | 1 | SB+D+X | | | | | | 2 | LB+D+X | Indexed by X | | | | | 3 | XB+D+X | | | 0 | 1 | 1 | 0 | I(PB D) | | | | | | 1 | I(SB+D) | Indirect | | | | | 2 | I(LB+D) | | | | | | 3 | I(XB+D) | | | 1 | 0 | 0 | 0 | I(PB D+Y) | | | | | | 1 | I(SB+D+Y) | Preindexed by Y | | | | | 2 | I(LB+D+Y) | | | | | | 3 | I(XB+D+Y) | | | 1 | 0 | 1 | 0 | I(PB D) + Y | | | | | | 1 | I(SB+D)+Y | Postindexed by Y | | | | | 2 | I(LB+D)+Y | | | | | | 3 | I(XB+D)+Y | | | 1 | 1 | 0 | 0 | I(PB D+X) | | | | | | 1 | I(SB+D+X) | Preindexed by X | | | | | 2 | I(LB+D+X) | | | | | | 3 | I(XB+D+X) | | | 1 | 1 | 1 | 0 | I(PB D) + X | | | - | - | - | 1 | I(SB+D)+X | Postindexed by X | | | | | 2 | I(LB+D)+X | - commanded by 11 | | | | | 3 | I(XB+D)+X | | # Instruction definitions - SRV #### ADDRESSING MODE—ADMOD Set the addressing mode of the machine. ## E16S Enter 16S mode Use 16S address calculations to form subsequent effective addresses and enable S-mode interpretation of instruction. See section on address resolution for details. MODES=SRV, FORMAT=GEN, OPCODE=000011, C=unchanged, L=unchanged, CC=unchanged. #### E32S Enter 32S mode Use 32S address calculations to form subsequent effective addresses and enable S-mode interpretation of instructions. See section on address resolution for details. MODES=SRV, FORMAT=GEN, OPCODE=000013, C=unchanged, L=unchanged, CC=unchanged. #### E32R Enter 32R mode Use 32R address calculations to form subsequent effective addresses and enable R-mode interpretation of instructions. See section on address resolution for details. MODES=SRV, FORMAT=GEN, OPCODE=001013, C=unchanged, L=unchanged, CC=unchanged. #### E64R Enter 64R mode Use 64R address calculations to form subsequent effective addresses and enable R-mode interpretation of instructions. See section on address resolution for details. **MODES**=SRV, **FORMAT**=GEN, **OPCODE**=001011, **C**=unchanged, **L**=unchanged, **CC**=unchanged. #### E64V Enter 64V mode Use 64V address calculations to form subsequent effective addresses and enable 64V-mode interpretation of instructions. See section on address resolution for details. **MODES**=SRV, **FORMAT**=GEN, **OPCODE**=000010, **C**=unchanged, **L**=unchanged, **CC**=unchanged. #### E32I Enter 32I mode Use 32I address calculations to form subsequent effective addresses and enable 32I-mode interpretation of instructions. See section on address resolution for details. **MODES**=SRV, **FORMAT**=GEN, **OPCODE**=001010, **C**=unchanged, **L**=unchanged, **CC**=unchanged. #### **BRANCH—BRAN** The branch instructions are two word generics which test the contents of a register or the result of a previous ARITHMETIC or COMPARE operation, as indicated by the condition codes (CC), the C-bit, and the L-bit. The bit layout is: Condition code branches test six conditions based on the LT bit, the EQ bit, and the opcode. | Condition | Meaning | |-----------|---------------------------------------------| | < | Branch if LT bit set and EQ bit cleared | | € | Branch if LT bit set or EQ bit set | | = | Branch if EQ bit set | | <b>≠</b> | Branch if EQ bit cleared | | ≽ | Branch if LT bit cleared or EQ bit set | | > | Branch if LT bit cleared and EQ bit cleared | MODES=V, FORMAT=BRAN, OPCODE=see charts below, C=unchanged, L=unchanged, CC=unchanged. ## Test condition code and branch These instructions have the following format: $$\begin{array}{c} \textbf{Branch if condition code} & \left( \begin{array}{c} LT \\ LE \\ EQ \\ NE \\ GE \\ GT \end{array} \right) \end{array}$$ For example: BCLT addr means Branch to addr if the condition code is less than zero (LT bit set and EQ bit cleared). | Mnemonic | Function | Opcode | |-----------|----------------------|--------| | BCLT addr | If CC<, then addr→PC | 141604 | | BCLE addr | If CC≼, then addr→PC | 141600 | | BCEQ addr | If CC=, then addr→PC | 141602 | | BCNE addr | If CC≠, then addr→PC | 141603 | | BCGE addr | If CC≽, then addr→PC | 141605 | | BCGT addr | If CC>, then addr→PC | 141601 | ## Test magnitude condition and branch These instructions have the following format: Branch to addr if L=1 and condition code $$\begin{cases} LT \\ LE \\ EQ \\ NE \\ GE \\ GT \end{cases}$$ For example: BMLT addr means Branch to addr if the L-bit is set and condition code is less than 0 (LT bit set and EQ bit cleared). | Mnemonic | Function | Opcode | |-----------|------------------------------|--------| | BMLT addr | If L=1 and CC<, then addr→PC | 141707 | | BMLE addr | If L=1 and CC≤, then addr→PC | 141711 | | BMEQ addr | If L=1 and CC=, then addr→PC | 141602 | | BMNE addr | If L≠1 and CC≠, then addr→PC | 141603 | | BMGE addr | If L=1 and CC≥, then addr→PC | 141606 | | BMGT addr | If L=1 and CC>, then addr→PC | 141710 | ## Test C-bit and branch Branch if C-bit $$\begin{cases} 0 \\ 1 \end{cases}$$ BCR addr Branch if C-bit reset (equals zero): If C-bit=0, then addr→PC. OPCODE=141705. BCS addr Branch if C-bit set (equals one): If C-bit=1, then addr→PC. OPCODE=141704. Test L-bit BLR addr Branch if L-bit reset (equals zero): If L-bit=0, then addr →PC. OPCODE=141707. BLS addr Branch if L-bit set (equals one): If L-bit=1, then addr→PC. ## Branch on register These instructions have the following format: $$\begin{array}{c} \text{Branch if} & \left\{ \begin{matrix} \text{A-Register (blank)} \\ \text{L-Register (L)} \\ \text{Floating-Register (F)} \end{matrix} \right\} & \left\{ \begin{matrix} \text{LT} \\ \text{LE} \\ \text{EQ} \\ \text{NE} \\ \text{GE} \\ \text{GT} \end{matrix} \right\} & 0 \end{array}$$ For example: BLT addr means Branch to addr if the contents of the A register is less than zero (LT bit is set and EQ bit is cleared). **MODES**=V, **FORMAT**=BRAN, **OPCODES**=see chart below, **C**=unchanged, **L**=unchanged, **CC**=result. | Function | Opcode | |------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | If A<0, then addr→PC | 140614 | | If A≤0, then addr→PC | 140610 | | If A=0, then addr→PC | 140612 | | If A≠0, then addr→PC | 140613 | | If A≽0, then addr→PC | 140615 | | If A>0, then addr→PC | 140611 | | If L<0, then addr→PC | 140614 | | If L≤0, then addr→PC | 140700 | | If L=0, then addr→PC | 140702 | | If $L\neq 0$ , then $addr\rightarrow PC$ | 140703 | | If L≥0, then addr→PC | 140615 | | If L>0, then addr→PC | 140701 | | If F<0, then addr→PC | 141614 | | If F≼0, then addr→PC | 141610 | | If F=0, then addr→PC | 141612 | | If F≠0, then addr→PC | 141613 | | If F≥0, then addr→PC | 141615 | | If F>0, then addr→PC | 141611 | | | If A<0, then addr→PC If A≤0, then addr→PC If A=0, then addr→PC If A≠0, then addr→PC If A>0, then addr→PC If A>0, then addr→PC If L<0, then addr→PC If L<0, then addr→PC If L=0, then addr→PC If L≠0, then addr→PC If L≠0, then addr→PC If L>0, then addr→PC If F<0, then addr→PC If F<0, then addr→PC If F<0, then addr→PC If F=0, then addr→PC If F=0, then addr→PC If F≠0, then addr→PC If F≠0, then addr→PC If F≠0, then addr→PC | ## Increment or decrement X or Y and branch $\left\{\begin{array}{l} Increment \\ Decrement \end{array}\right\} \quad \left\{\begin{array}{l} X \\ Y \end{array}\right\} \text{ by 1 then branch to addr if result } \neq 0$ **MODES**=V, **FORMAT**=BRAN, **OPCODE**=see chart below, **C**=unchanged, **L**=unchanged, **CC** =unchanged. | Mnemonic | Function | Opcode | |----------|-------------------------------------------------------------|--------| | BIX addr | $X+1\rightarrow X$ ; if $X\neq 0$ then $addr\rightarrow PC$ | 141334 | | BIY addr | Y+1→Y;if Y≠0 then addr→PC | 141324 | | BDX addr | $X-1\rightarrow X$ ; if X≠0 then addr→PC | 140734 | | BDY addr | $Y-1\rightarrow Y$ ; if Y≠0 then addr→PC | 140724 | # CGT Computed GOTO If $1 \le A <$ , then $[PC+A] \rightarrow PC$ else $PC+n \rightarrow PC$ Instruction word followed by n further words: word 1 contains integer n and words 2-n contain branch addresses within the current procedure segment. If the contents of register A is less than n and greater than or equal to 1, then control passes to the address in PC+A; otherwise no branch is taken and control passes to PC+n. **MODES** =V, **FORMAT**=GEN, **OPCODE**=001314, **C**=unspecified, **L**=unspecified, **CC**=unspecified. #### CHARACTER STRING OPERATIONS—CHAR These instructions use the field address and length registers (FALR) which have been set up by field operation instructions prior to the use of these instructions. Character string operations perform memory to memory operations on variable length character fields. The FAR is used as a byte pointer and the bit offset (low order 3 bits) is ignored. **Data type**: Characters are 8-bit bytes. The format is unspecified and may be determined by programmer, e.g., ASCII, EBCDIC, etc. The translate instruction (ZTRN), for example uses a table set up by the programmer to translate one character code into another. #### LDC FALR Load character If field length register FLR is nonzero, load the single character pointed to by field address register FAR into A register bits 9-16. A register bits 1-8 are cleared. The field address register is advanced 8 bits to the next character, and the field length register is decremented by 1. Set condition code NE (clear EQ). If the specified field length register is zero, then set the condition code EQ. MODES=V, FORMAT=CHAR, FALR 0 OPCODE=001302, FALR 1 OPCODE=001312, C=unchanged, L=unchanged, CC=result. ## ► STC FALR Store character Store bits 9-16 of the A register into the character pointed to by field address register. The field address register is advanced 8 bits to the next character, and the field length register is decremented by 1. Set the condition code NE. If the field length register is zero, set the condition code EQ and do not store. MODES=V, FORMAT=CHAR, FALR 0 OPCODE=001322, FALR 1 OPCODE=001332, C=unchanged, L=unchanged, CC=result. ## **ZCM** Compare character field Compare field 0 to field 1 and set condition codes based on the results. If the fields are not of equal length, the shorter field is logically padded with ASCII blanks ('240). #### Setup: | FAR 0 | Field 0 address (byte aligned). | |-------|----------------------------------| | FLR 0 | Length of field 0 in characters. | | FAR 1 | Field 1 address (byte aligned). | | FLR 1 | Length of field 1 in characters. | | Condition code | Result | |------------------|-------------------------------------| | EQ | Field 0=field 1 | | LT | Field 0 <field 1<="" td=""></field> | | GT ((LT and EQ)) | Field 0>field 1 | MODES=V, FORMAT=CHAR, OPCODE=001117, C=unchanged, L=unchanged, CC=results. #### ZED Edit character field Move characters from field 0 into field 1 under the control of an edit program pointed to by XB. Movement stops when the source field is exhausted or when the end of the edit program is reached. Edit Program Word: | L | | 0 | E | М | |---|------|--------------------|--------|--------------------------------------------| | 1 | 2 | 6 | 7-8 | 9 16 | | | L | Last entry if set. | | | | | 0 | Must be zero. | | | | | E | Edit opcode. | | | | | M | Edit modifier. | | | | | Opco | de (E) Mnemonic | Defin | nition | | | 0 | CPC | Copy | y M characters from source to destination. | | | 1 | INL | Inser | rt literal character M. | | | 2 | SKC | Skip 1 | M characters. | | | 3 | BLK | Supp | ply M blanks (ASCII '240). | #### Setup: FAR 0 Address of source field (byte aligned). FAR 1 Address of destination field (byte aligned). FLR 1 Number of characters to move and edit. XB Address of edit program. MODES=V, FORMAT=CHAR, OPCODE=001111, C=unchanged, L=unchanged, CC=unchanged. #### **ZFIL** Fill field Store the character contained in bits 9-16 of the A register into each character of field 1. Setup: A(9-16) Character to fill. FAR 1 Destination field address (byte aligned). FLR 1 Destination field length in bytes. MODES=V, FORMAT=CHAR, OPCODE=001116, C=unchanged, L=unchanged, CC=unchanged. #### ZMV Move character field Move characters from field 0 to field 1, going from left to right. If the source field is shorter than the destination field, the destination field is padded with ASCII blanks ('240). If the source field is longer than the destination field, the remainder of the source field is not moved. The field address and length registers are left in an undefined state by this operation. Setup: FAR 0 Source field address (byte aligned). FLR 0 Source field length in bytes. FAR 1 Destination field address length (byte aligned). **FLR 1** Destination field length in bytes. **MODES**=V, **FORMAT**=CHAR, **OPCODE**=001114, **C**=unchanged, **L**=unchanged, **CC**=unchanged. # ZMVD Move equal length fields Move characters from field 0 to field 1. There is no padding or truncation since only the number of characters to be moved is specified. Setup: **FAR 0** Source field address (byte aligned). FAR 1 Destination field address (byte aligned). FLR 1 Number of characters to move. $$\label{eq:modes} \begin{split} \textbf{MODES} \!\!=\!\! \text{V}, & \textbf{FORMAT} \!\!=\!\! \text{CHAR}, & \textbf{OPCODE} \!\!=\!\! 001115, & \textbf{C} \!\!=\!\! \text{unchanged}, & \textbf{L} \!\!=\!\! \text{unchanged}, & \textbf{CC} \!\!=\!\! \text{unchanged}. \end{split}$$ # ZTRN Translate character field Use each character in field 0 as an index into the 256 byte table addressed by the XB register. Store each selected table character in the successive characters of field 1. Source and destination length are the same, specified by field length register 1. Setup: **FAR 0** Source field address (byte aligned). FAR 1 Destination field address (byte aligned). FLR 1 Number of characters to translate and move. **XB** Address of 256-byte translate table. For example: the source field contains a character A. The ASCII code is '301. Thus, the translate table location '301, which contains a \$, is accessed. This \$ is put into the destination field. $$\label{eq:modes} \begin{split} \textbf{MODES} \!\!=\!\! \text{V}, & \textbf{FORMAT} \!\!=\!\! \text{CHAR}, & \textbf{OPCODE} \!\!=\!\! 001110, & \textbf{C} \!\!=\!\! \text{unchanged}, & \textbf{L} \!\!=\!\! \text{unchanged}, & \textbf{CC} \!\!=\!\! \text{unchanged}. \end{split}$$ ## CLEAR REGISTER—CLEAR # CAL Clear A left byte #### $0 \to A(1-8)$ Clear bits 1-8 of register A without affecting bits 9-16. MODES=SRV, FORMAT=GEN, OPCODE=141050, C=unchanged, L=unchanged, CC=unchanged. # CAR Clear A right byte #### $0 \rightarrow A(9-16)$ Clear bits 9–16 of register A without affecting bits 1–8. MODES=SRV, FORMAT=GEN, OPCODE=141044, C=unchanged, L=unchanged, CC=unchanged. # CRA Clear the A register #### $0\rightarrow A$ Reset the contents of register A to zero. **MODES**=SRV, **FORMAT**=GEN, **OPCODE**=140040, **C**=unchanged, **L**=unchanged, **CC**=unchanged. ## CRB Clear the B register $0 \rightarrow B$ Reset the contents of register B to zero. MODES=SRV, FORMAT=GEN, OPCODE=140015, C=unchanged, L=unchanged, CC=unchanged. #### CRE Clear E 0→E Reset the contents of register E to zero. MODES=V, FORMAT=GEN, OPCODE=141404, C= unchanged, L=unchanged, CC=unchanged. ## CRL Clear long $0\rightarrow L$ Reset the contents of register L to zero. **MODES**=SRV, **FORMAT**=GEN, **OPCODE**=140010, **C**=unchanged, **L**=unchanged, **CC**=unchanged. ## CRLE Clear L and E $0\rightarrow L$ , $0\rightarrow E$ Reset the contents of registers L and E to zero. MODES=V, FORMAT=GEN, OPCODE=141410, C=unchanged, L=unchanged, CC=unchanged. ## DECIMAL ARITHMETIC—DECI These instructions use the field address and length registers which have been set up by field operation instructions prior to the use of the decimal arithmetic instruction. The general setup is: EAFA 0 Source field address. EAFA 1 Destination field address. LDL Control word (described below) decimal operation. Variations on this pattern are discussed in the appropriate instructions. #### Decimal data types The decimal instruction set operates on five types of decimal data. Table 11-1 summarizes the characteristics of each type. | Tab | le | 11-1. | Deci | mal | Data | Type. | |-----|----|-------|------|-----|------|-------| | | | | | | | | | Туре | Code | Size of<br>Decim<br>Digit | a l<br>Comments | | | | |------------------------------|------|---------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------|---------------------------------------------------------|--| | Leading<br>Separate<br>Sign | 0 | 8 | A plus sign (+) or a space represents positive number. Operations generate +. minus sign (-) represents negative number | | | | | Trailing<br>Separate<br>Sign | 1 | 8 | | | | | | Packed<br>Decimal | 3 | 4 | lowed by si | | ent each digit, fo<br>ires odd number o<br>te boundary. | | | Leading<br>Embedded<br>Sign | 4 | 8 | A single character represents a digit and the sign of the field. When more than one character is listed, all will be recognized, but only first will be given in result field. | | | | | Trailing<br>Embedded<br>Sign | 5 | 8 | | sign characters | | | | | | | Digit | Positive | Negative | | | | | | 0 | 0,+{ | -,{ | | | | | | 1 | 1 A | J. | | | | | | 2 | 2 B | K | | | | | | 3 | 3 C | L | | | | | | 4 | 4 D | M | | | | | | 5 | 5 E | N | | | | | | 6 | 6 F | О | | | | | | 7 | 7 G | P | | | | | | 8 | 8 H | Q | | | | | | 9 | 9 I | R | | # Arithmetic instruction register usage (I-mode only) All arithmetic instructions use general registers GR0, GR1, GR3, GR4, and GR6, FLR0, FLR1 as scratch registers. These registers are not guaranteed to remain the same if an arithmetic instruction is executed. ## Control word format To specify the characteristics of the operation to be performed, most decimal arithmetic instructions require a control word to be loaded in the L register (general register 2 in I-mode). The general format is as follows: #### Where: - A Field 1, number of digits. - E Field 1, decimal data type (see Table 11-1). - B If set, sign of field 1 is treated as negation of its actual value. - If set, sign of field 2 is treated as negation of its actual value (XAD, XMP, XDV, XCM only). - **D** If set, then round (XMV only). - F Field 2, number of digits. - H Field 2, decimal data type. - G Scale differential (XAD, XMV, XCM only). - T Generate positive results always. - Unused, must be zero. The fields used by each instruction are listed in the instruction descriptions. Fields not used by an instruction must be zero. The scale differential specifies the difference in decimal point alignment between the operator and fields for some instructions. This field is treated as a signed 7 bit two's complement number, where a positive value indicates a right shifting of field 1 with respect to field 2, and a negative value indicates a left shifting. ## Decimal exception (DEX) There are two ways that an exception is handled. If the program is running in decimal exception mode, the a directed fault (similar to floating exception) is taken with the following fault codes: | | DEX Type (High) | Sub Code (Low) | |----------------|-----------------|----------------| | Overflow | 7 | 0 | | Divide by zero | 7 | 1 | | Conversion | 7 | 2 | When not in decimal exception mode, the C bit is set and execution continues with the next instruction. # XAD Decimal add Add the source field to the destination field and place the results in the destination field. The control word determines: - 1. The operation—addition or subtraction. - 2. The scaling of the results. Operations: The B and C fields control whether the operation is an add or subtract. | В | С | Operation | |---|---|------------------------------------------| | 0 | 0 | + Source + Destination | | 0 | 1 | + Source $-$ Destination | | 1 | 0 | <ul><li>Source + Destination</li></ul> | | 1 | 1 | <ul> <li>Source – Destination</li> </ul> | Scaling: G Field. The scale differential field in the control word is used to adjust field 1 in relation to field 2. If the scale differential is greater than zero, low order digits in field 1 will only affect the initial borrow from the low order digit of field 2. If the scale differential is less than zero, field 1 is considered to be logically extended with low order zeros when applied to field 2. MODES=V, FORMAT=DECI, OPCODE=001100, C=overflow, L=unchanged, CC=result. ## XBTD Binary to decimal conversion | Α | | | Ε | | | Н | |-----|---|----|-------|----|----|-------| | 1-6 | 7 | 13 | 14-16 | 17 | 29 | 30-32 | Converts a 16, 32 or 64 bit signed binary number to decimal. The H field in the control word specifies the length and location of the binary source as follows: - 0 16 Bits, located in EH - 1 32 Bits, located in E - 2 64 Bits, located in F The condition codes are undefined for this operation. A conversion error exception is taken on overflow – see decimal exception. This instruction converts the binary field present in EH, E or F (depending on field type) into a decimal field. Unlike the rest of the decimal arithmetic instructions, XBTD returns the decimal field in what elsewhere is known as the "source" field address register. **MODES**= V, FORMAT=DECI, OPCODE=001145, C=unchanged, L=unchanged, CC=unchanged. # XCM Decimal compare Sets the condition codes to reflect the comparison Field 2 :: Field 1 The scale difference applies as in XAD. The condition codes are set as follows: GT = Field 2 > Field 1 EQ = Field 2 = Field 1 LT = Field 2 < Field 1 MODES=V, FORMAT=DECI, OPCODE=001102, C=unchanged, L=unchanged, CC=result. ## XDTB Decimal to binary conversion | A | | | E | | | Н | | |-----|---|----|-------|----|----|-------|--| | 1-6 | 7 | 13 | 14-16 | 17 | 29 | 30-32 | | Converts the decimal field to binary. The length of the binary field is specified in the H field of the control word as follows: - 0 16 Bits, returned in A. - 1 32 Bits, returned in L. - 2 64 Bits, returned in L/E. A conversion error exception is taken on overflow. The condition codes are undefined for this operation. Field address register 1 is not used by this instruction and can be used as an accumulator for indexed pointers. This instruction returns a 16, 32 or 64 bit integer in either the A, L, or L/E registers, depending on the destination field type. **MODES=V**, **FORMAT=DECI**, **OPCODE=001146**, **C**=unchanged, **L=**unchanged, **CC=**unspecified. #### XDV Decimal divide Divide destination field by source field, placing both the quotient and remainder in the destination field. The data type must be trailing sign embedded. To allow room for both quotient and remainder the destination field must contain the same number of leading zeros as the length of the source field. After divide the destination field contains quotient of length (destination length—source length) followed by remainder of source length. A decimal exception (DEX) occurs if the source =0, the sign is not trailing embedded, or the destination is $\leq$ source. MODES=V, FORMAT=DECI, OPCODE=001107, C=unchanged, L=unchanged, CC=result. ## XED Numeric edit Processes an edit sub-program addressed by the temporary base register (XB) to control the editing of the source field into the destination field. The source field must have leading separate sign, and must have the same number of digits and the same decimal point alignment as called for by the edit sub-program. Normal setup for the instruction would consist of a decimal move to correct the type, length, and alignment of the number to be edited. The A register must equal one if the source field is zero; otherwise the A register must be zero. The edit sub-program consists of a list of words formatted as follows: | L | 0 | E | | М | |---|-----|-----|---|----| | 1 | 2-4 | 5-8 | 9 | 16 | #### Where: - L Last entry if set. - E Edit opcode. - M Edit modifier. The XED instruction maintains several internal variables during its processing which are used to control the operation. These variables are: - Zero suppress character—initial value is blank (ASCII '240). - Floating edit character—initially not defined. - Sign of the source field—established by fetching the first character of the source field. - Significance flag—records the end of zero suppression. $$\label{eq:modes} \begin{split} \textbf{MODES} \!\!=\!\! \text{V}, & \textbf{FORMAT} \!\!=\!\! \text{DECI}, & \textbf{OPCODE} \!\!=\!\! 001112, & \textbf{C} \!\!=\!\! \text{unchanged}, & \textbf{L} \!\!=\!\! \text{unchanged}, & \textbf{CC} \!\!=\!\! \text{unchanged}. \end{split}$$ ## XMP Decimal multiply | Α | - | В | С | _ | T | . — | Е | F | G | н | |-----|-----|---|----|----|----|-----|-------|-------|-------|-------| | 1-6 | 7-8 | 9 | 10 | 11 | 12 | 13 | 14-16 | 17-22 | 23-29 | 30-32 | Multiply the multiplicand, in the source field, by the multiplier, in the destination field. The product is right justified in the destination field. To avoid overflow the destination field length must be greater than or equal to the number of significant digits in the multiplier plus the number of significant digits in the multiplicand. For example, to multiply 1234 by 567 set A=4, F=7, G=3. Note that the temporary base register (XB) is used by the instruction and may change. MODES=V, FORMAT=DECI, OPCODE=001104, C=overflow, L=unchanged, CC=result. | Table 11- | 2. Edit Sub-o | perations | |-----------|---------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | Opcode | Mnemonic | Definition | | 00 | ZS | Zero suppress next M digits. Digits are consecutively fetched from the source field and the significance flag is checked. If the significance flag is set, the digit is copied to the destination field. If the significance flag is clear and the digit is non-zero, the significance flag is set, the floating character inserted (if it is currently defined), and the digit is copied. Otherwise the zero suppress character is substituted for the zero digit in the destination field. | | 01 | IL | Insert literal M in destination field. | | 02 | SS | Set zero suppress character to M. | | 03 | ICS | Insert literal M if the significance flag set; otherwise insert zero suppress character. | | 04 | <b>ID</b> | Insert M digits. If significance flag is clear, it is set and the floating edit character inserted (if currently defined). Then copy M digits into the destination field. | | 05 | ICM | Insert M if sign is minus; otherwise insert zero suppress character. | | 06 | ICP | Insert M if sign is plus; otherwise insert zero suppress character. | | . 07 | SFC | Set floating character to M. | | 10 | SFP | Set floating character to M if sign plus; otherwise set floating edit character to zero suppress character. | | 11 | SFM | Set floating character to M if sign minus; otherwise set floating edit character to zero suppress character. | | . 12 | SFS | Set floating character to sign. | | 13 | JZ | Jump M+1 locations ahead in edit sub program if source field equals zero. | | 14 | FS | Fill next M characters with zero suppress character. | | 15 | SF | Set significance flag. | | 16 | IS | Insert sign. | ## XMV Decimal move Moves source to destination, changing the sign if the B bit in the control word is set, and rounding if the D bit is set and G, the scale differential, is greater than zero. If the scale differential is negative then zeros are supplied before field 1 is used for a source. The condition codes are set to reflect the state of the destination after the move. MODES=V, FORMAT=DECI, OPCODE=001101, C=unchanged, L=unchanged, CC=result. #### FIELD OPERATIONS—FIELD These instructions set up and manipulate the field address and length registers, which are used by both the decimal and character string instructions. The interpretation of the value in the field length registers depends on the data type and instruction using them. ## ALFA FAR Add L to field address L+FAR→FAR Add the 32-bit integer in register L, which represents an offset in bits, to the 26-bit unsigned word and bit number fields of the field address register. The low-order 26 bits of the sum replace the word and bit number fields of the field address register. All but the low order 20 bits of the sum must be zero. Example: to advance FAR 0 by 3 bytes, place 24 into the L register and execute ALFA 0. MODES=V, FORMAT=GEN, FAR 0 OPCODE=001301, FAR 1 OPCODE=001311, C=unspecified, L=unspecified, CC=unchanged. # EAFA FAR, addr Effective address to field address register [EA]48→FAR Place the complete effective address, including the bit portion, in field address register FAR. The associated field length register is unchanged. MODES=V, FORMAT=AP, FAR 0 OPCODE=001300, FAR 1 OPCODE=001310, C=unchanged, L=unchanged, CC=unchanged. # LFLI FLR,DATA Load field length register immediate DATA→FLR Place the 16-bit unsigned integer in the second word of the instruction into field length register FLR. Clear the high order bits. This instruction loads the field length register with a constant which is 65535 or less. The associated field address register is unchanged. **MODES** =V, FORMAT=BRAN, FLR 0 OPCODE=001303, FLR 1 OPCODE=001313, C=unchanged, L= unchanged, CC=unchanged. # STFA FAR,addr Store field address register $FAR \rightarrow [EA]32$ or [EA]48 Store contents of field address register FAR into addr as a hardware indirect pointer. If bit number field of the field address register is zero, store the first two words of the pointer and clear the pointer's extend bit; if bit number field is non-zero, store all three words of the pointer and set the pointer's extend bit. MODES=V, FORMAT=AP, FAR 0 OPCODE=001320, FAR 1 OPCODE=001330, C=unchanged, L=unchanged, CC=unchanged. # TFLL FLR Transfer field length register to L FLR→L Transfer the contents of field length register FLR to the L register as an unsigned 32-bit integer. Clear the high order 11 bits of L. MODES=V, FORMAT=GEN, FLR 0 OPCODE=001323, FLR 1 OPCODE=001333, C=unchanged, L=unchanged, CC=unchanged. # TLFL FLR Transfer L-register to field length register L→FLR Transfer the 32-bit unsigned integer in the L register into field length register FLR. The high order 11 bits of L must be zero to make the high order 6 bits of the field length register equal to zero. This instruction is used to load the field length register with a value computed at execution time. The maximum allowable field length is 2\*\*20 (21 bits) – the number of bits in a 64K segment. MODES=V, FORMAT=GEN, FLR 0 OPCODE=001321, FLR 1 OPCODE=001331, C=unchanged, L=unchanged, CC=unchanged. #### FLOATING POINT ARITHMETIC—FLPT See Section 9 for a description of the processor dependent register formats and the floating point data structures. #### Normalization The result of every floating point calculation is normalized. In normal form, the most significant digit of the mantissa follows the binary point. If an operation produces a mantissa that is smaller than normal, the mantissa is shifted left until the most significant bit differs from the sign bit, and the exponent is decreased by one for each shift. Bits vacated at the right are filled by zeros. If the result of an operation overflows the mantissa, it is shifted right one place, the overflow bit is made the most significant bit, and the exponent is increased by 1. ## Floating point exceptions In the basic arithmetic operations, increasing the exponent in the floating point register beyond 32639 is an overflow; decreasing it below -32896 is an underflow. An attempt to store a single-precision number with an exponent greater than 127 or less than -128 in the two-word memory format results in a different type of exception – see Table 11-2. The number in the floating point register is not altered by the FST operation and so can be recovered if necessary. Other detected exceptions are an attempt to divide by zero or to form an integer exceeding $\pm 30$ bits or about $\pm 1$ billion decimal. On the Prime 350 and up, the floating point exception is a fault rather than an interrupt and is controlled by the floating point exception bit in the keys – see Section 9 – Data Formats. | Regis | ter 11 (Precision) | Register 12 | Type of Exception | |--------|--------------------|--------------|----------------------------------------------------------------------------------------| | Single | Double | | | | \$100 | \$200 | | Overflow/Underflow (Exponent exceeds approx. $10 \pm 9800$ ) | | \$101 | \$201 | | Division by zero | | \$102 | | (EA) | Attempt to store single precision exponent exceeding 8-bit memory format (>127, <-128) | | \$103 | | | Attempt to form integer exceeding capacity. INT: A B (30 bits) INTA: A (15 bits) | | | | | INTL: L (31 bits) | | | | | Note | | | | \$ indicates | hexadecimal codes | | Field | Single<br>Precision-<br>Memory | Single<br>Precision-<br>Register | Double<br>Precision | |-----------------|--------------------------------|----------------------------------|----------------------------------------------------| | Mantissa (two's | complement) | | | | Bits | 23 + Sign | 31 + Sign | 47 + Sign | | Precision | ±8,388,607 | $\pm 2,147,483,647$ | ±140,737,488,355,327 | | Exponent | | | | | Bits | 8 | 16 | 2 16 1. See 18 18 18 18 18 18 18 18 18 18 18 18 18 | | Range | -128 to +127 | -32896 to +32639 | -32896 to +32639 | | | (10±38) | (10+9823,-9902) | (10+9823,-9902) | ## DFAD addr Double precision floating add $F+[EA]64\rightarrow F$ Add the double precision number starting at addr to the double precision number in the floating point register and leave the result in the floating point register. (Same procedure as FAD except a 47-bit mantissa is produced.) MODES=RV, FORMAT=MR, OPCODE=06 02, C =overflow, L=unspecified, CC=unspecified. # DFCM Double precision floating complement -F→F Two's complement the precision mantissa in floating point register and normalize if necessary. MODES=RV, FORMAT=GEN, OPCODE=140574, C=overflow, L=unspecified, CC=unspecified. # DFCS addr Double precision floating point compare and skip If F>[EA]64 then $PC\rightarrow PC$ If F=[EA]64 then $PC+)1\rightarrow PC$ If F<[EA]64 then $PC+2\rightarrow PC$ If the contents of the floating point register is greater than the contents of addr, execute the next instruction. If the contents of the floating point register equals the contents of addr, skip the next location in instruction sequence and execute the instruction at second location following. If the contents of the floating point register is less than the contents of addr, skip next two locations in instruction sequence and execute the instruction at third location following. MODES=RV, FORMAT=MR, OPCODE=11 02, C=unspecified, L=unspecified, CC=unspecified. # DFDV addr Double precision floating divide F/[EA]64→F Divide the contents of the floating point register by the number in addr and place the quotient in the floating point register with the mantissa normalized. MODES=RV, FORMAT =MR, OPCODE=17 02, C=overflow division by zero, L=unspecified, CC=unspecified. ## ▶ DFLD addr Double precision floating load [EA]64→F Load the double precision floating point number contained in the four memory words at addr into the floating point register. MODES=RV, FORMAT=MR, OPCODE=02 02, C= unchanged, L=unchanged, CC=unchanged. # DFLX addr Double precision floating load index [EA]16\*4→X Quadruple the contents of the effective address and load the result into the index register X. This instruction is useful for addressing arrays or tables of element size four words. MODES=V, FORMAT=MR, OPCODE=15 02, C=unchanged, L=unchanged, CC=unchanged. # ▶ DFMP addr Double precision floating multiply F\*[EA]64→F Multiply the contents of the floating point register by the contents of addr and place the products in the floating point register with the mantissa normalized. MODES=RV, FORMAT =MR, OPCODE=16 02, C=overflow, L=unspecified, CC=unspecified. # DFSB addr Double precision floating subtract F-[EA]64→F Subtract the double precision floating point number starting at addr from the double precision floating point number in the floating point register. (Same procedure as FSB except a 47-bit mantissa is produced.) MODES=RV. FORMAT=MR, OPCODE=07 02, C= overflow, L=unspecified, CC=unspecified. # ▶ DFST addr Double precision floating store $F \rightarrow [EA]64$ Store the double precision floating point number contained in the floating point register into the location specified by addr. Exponent and mantissa bit capacities are the same so that no floating point exceptions are possible. MODES=RV, FORMAT=MR, OPCODE=04 02, C= unchanged, L=unchanged, CC=unchanged. # FAD addr Floating add $F+[EA]32\rightarrow F$ Add the floating point number at addr to the contents of the floating point register and leave the resulting floating point number in the floating point register. Addition of floating point numbers is accomplished by right shifting the smaller number by the difference in the exponents. After alignment, the mantissas are added. If there is an overflow from the most significant bit (not the sign), the sum mantissa is shifted right one place, the exponent is incremented by one and the overflow bit becomes the high-order bit in the normalized mantissa. If the result is otherwise not in normal form (as when numbers with unlike signs are added), the result is normalized. Overflow cannot occur. The C-Bit is cleared. MODES=RV, FORMAT=MR, OPCODE=06 01, C=cleared, L=unspecified, CC=unspecified. ## FCM Complement $-F \rightarrow F$ Two's complement the double precision mantissa in floating point register and normalize if necessary. **MODES**=RV, **FORMAT**=GEN, **OPCODE**=140574, **C**=overflow, **L**=unspecified, **CC**=unspecified. ## FCS addr Floating compare and skip If F>[EA]32, then $PC\rightarrow PC$ If F=[EA]32, then $PC+1\rightarrow PC$ If F<[EA]32, then $PC+2\rightarrow PC$ If the contents of the floating point register is greater than the contents of addr, execute the next instruction. If the contents of the floating point register equals the contents of addr, skip the next location in instruction sequence and execute the instruction at second location following. If the contents of the floating point register is less than the contents of addr, skip next two locations in instruction sequence and execute the instruction at third location following. MODES=RV, FORMAT=MR, OPCODE=11 01, C=unspecified, L=unspecified, CC=unspecified. ## FDBL Convert single to double float $F \rightarrow F$ Convert the single precision floating point number in the floating point register to a double precision precision floating point number in the floating point register. **MODES=V**, **FORMAT=GEN**, **OPCODE=**140016, **C=unchanged**, **L=unchanged**, **CC=unchanged**. # FDV addr Floating divide F/[EA]32→F Divide the contents of the floating point register by the number in addr and place the quotient, with the mantissa normalized, in the floating point register. MODES=RV, FOR-MAT=MR, OPCODE=17 01, C=overflow division by zero, L=unspecified, CC=unspecified. ## FLD addr Floating load |EA|32→F Load the double precision number contained in the two successive words at addr into the floating point register. **MODES**=RV, **FORMAT**=MR, **OPCODE**=02 01. **C**=unchanged, **L**= unchanged, **CC**=unchanged. # FLOT Convert 31-bit integer to float $Float(A|B) \rightarrow F$ Take the 31-bit integer in the combined A|B register and convert it into a normalized floating point number in the floating point register. MODES=R, FORMAT=GEN, OPCODE=140550, C=unspecified, L=unspecified, CC=unspecified. ## ► FLTA Convert integer to float #### $FLOT(A) \rightarrow F$ Convert the 16 bit integer in register A to a single precision floating point number in the floating point register. **MODES**=V, **FORMAT**=GEN, **OPCODE**=140532, **C**=overflow, **L**= unspecified, **CC**=unspecified. ## FLTL Convert long integer to float $$FLOT(L) \rightarrow F$$ Convert the 32 bit integer in register L to a single precision floating point number in the floating point register. MODES=V, FORMAT=GEN, OPCODE=140535, C=overflow, L=unspecified, CC=unspecified. ## FLX addr Floating load index Double the contents of the effective address and load the result into the index register X. This instruction facilitates indexing sequences that involve double-word memory reference operations. It works directly for two-word indexing, e.g., 31-bit or 32-bit integer or floating point. MODES=RV, FORMAT=MR, OPCODE=15 01, C=unchanged, L=unchanged, CC= unchanged. ## FMP addr Floating multiply Multiply the contents of the floating point register by the contents of addr and place the product in the floating point register, with the mantissa normalized. MODES=RV, FORMAT =MR, OPCODE=16 01, C=overflow, L=unspecified, CC=unspecified. # FRN Round up If bit 25 of the mantissa in the floating point register is 1, add 1 to bit 24 and clear 25. **MODES** =RV, **FORMAT**=GEN, **OPCODE**=140534, **C**=overflow, **L**=unspecified, **CC**=unspecified. # FSB addr Floating subtract Subtract the contents of addr from the floating point register by aligning exponents, and proceding as in FAD except that the [EA]32 is subtracted from the floating point register. **MODES**=RV, **FORMAT**=MR, **OPCODE**=07 01, **C**=overflow, **L**=unspecified, **CC**=unspecified. # FSGT Floating skip if greater than zero If floating point register is greater than zero, skip next location. MODES=RV, FORMAT=GEN, OPCODE=140515, C=unchanged, L=unchanged, CC=unchanged. # FSLE Floating skip if less than or equal to zero If floating point register is less than or equal to zero, skip next location. MODES=RV, FORMAT=GEN, OPCODE=140514, C=unchanged, L=unchanged, CC=unchanged. ## FSMI Floating skip if minus If the floating point register is less than 0, skip next location. MODES=RV, FORMAT=GEN, OPCODE=140512, C=unchanged, L=unchanged, CC=unchanged. #### FSNZ Floating skip if not zero If the floating point register is not equal to zero, skip next location. If the floating point register is less than 0, skip next location. **MODES**=RV, **FORMAT**=GEN, **OPCODE**=140511, **C** = unchanged, **L**=unchanged, **CC**=unchanged. ## FSPL Floating skip if plus If the floating point register is greater than 0, skip next location. **MODES**=RV, **FORMAT**= GEN, **OPCODE**=140513, **C**=unchanged, **L**=unchanged, **CC**=unchanged. #### FST addr Floating store #### $F \rightarrow [EA]32$ Store the single precision floating point number contained in the floating point register in two memory words starting at addr. Bits 24–31 of the 31 bit mantissa are truncated when written into the 23-bit capacity memory storage. However, the mantissa may be rounded to bit 24 by a FRN instruction which adds 1 to bit 24 if bit 25 is 1. MODES=RV, FORMAT=MR, OPCODE=04 01, C=overflow, L=carry, CC=unchanged. ## FSZE Floating skip if zero If the floating point register is equal to zero, skip next location. MODES=RV, FORMAT=GEN, OPCODE=140510, C=unchanged, L=unchanged, CC=unchanged. ## INT Convert float to integer $$Int(F) \rightarrow A|B$$ Convert the single precision floating point number in the floating point register into a 32 bit integer in register L. The fractional part of the floating point register is lost. If the value in the floating point register is less than –(2\*\*31) or greater than 2\*\*31-1, set the C-bit or initiate a floating exception. MODES=V, FORMAT=GEN, OPCODE=140533, C=overflow, L=unspecified, CC=unspecified. ## ► INTA Convert float to integer #### $INT(F) \rightarrow A$ Convert the single precision floating point number in the floating point register into a 16 bit in integer in register A. The fractional part of the floating point register is lost. Overflow occurs if the value in the floating point register is less than -(2\*\*15) or greater than 2\*\*15-1, and sets the C-bit or initiates a floating exception. MODES=V, FORMAT=GEN, OPCODE=140531, C=overflow, L=unspecified, CC=unspecified. #### INTL Convert float to long integer #### $INT(F)\rightarrow L$ Convert the single precision floating point number in the floating point register into a 32 bit integer in register L. The fractional part of FAC is lost. If the value in the floating point register is less than -(2\*\*31) or greater than 2\*\*31-1, set the C-bit or initiate a floating exception. MODES=V, FORMAT=GEN, OPCODE=140533, C=overflow, L=unspecified, CC=unspecified. #### INTEGER ARITHMETIC—INT These instructions operate on 16, 31-bit and 32-bit signed integers. See Section 9 for a description of the data formats. #### A1A Add one to A #### $A+1\rightarrow A$ Add 1 to the 16-bit integer in register A and put the result into A. If the number incremented is 2 \*\*15-1, set C and give a result of -2\*\*15; otherwise clear C. **MODES**=SRV, **FORMAT**=GEN, **OPCODE**=141206, **C**=overflow, **L**=carry, **CC**=result. #### A2A Add two to A #### $A+2\rightarrow A$ Add 2 to the 16-bit integer in register A and put the result into A. If the number incremented is 2\*\*15-2 or 2\*\*15-1, set C and give a result of -2\*\*15 or-(2\*\*15-1); otherwise clear C. **MODES**=SRV, **FORMAT**=GEN, **OPCODE**=140304, **C**=overflow, **L**=carry, **CC**=result. #### ► ACA Add C-bit to A #### A+C-bit→A Add the C-bit to the 16-bit integer in register A and put the result into A (C is treated as same order of magnitude as bit 16 of A). If the number originally in A is 2\*\*15-1 and C set, set C and give a result of -2\*\*15; otherwise clear C. MODES=SRV, FORMAT=GEN, OPCODE=141216, C=overflow, L=carry, CC=result. #### ► ADD addr Add #### $A+[EA]16\rightarrow A$ Add the 16-bit integer at addr to the 16-bit integer in register A and put the result into register A. If the sum is greater than $2^{**}15$ or less than or equal to $-2^{**}15$ , set C; otherwise, clear C. In the first overflow case, the result has a minus sign, but a magnitude in positive form equal to the sum minus $2^{**}15$ ; in the second, the result has a plus sign, but a magnitude in negative form equal to the sum plus $2^{**}15$ . MODES=SRV, FORMAT=MR, OPCODE=06, C=overflow, L=carry, CC=result. #### ► ADL addr Add long #### $L+[EA]32\rightarrow L$ Add the 32-bit integer at addr to the 32-bit integer in register L and put the result into L. If the sum is greater than 2\*\*31 or less than -2\*\*31, set C; otherwise, clear C. In the first overflow case, the result has a minus sign, but a magnitude in positive form equal to the sum minus 2\*\*31; in the second, the result has a plus sign, but a magnitude in negative form equal to the sum plus 2\*\*31. MODES=V, FORMAT=MR, OPCODE=06 03, C=overflow, L=carry, CC=result. #### ADLL Add L bit to L L+keys(L)→L Add the link bit (L-bit in the keys) to the contents of the L register and put the result into the L register. Overflow may be set. This instruction is useful in implementing multiple precision arithmetic. MODES=V, FORMAT=GEN, OPCODE=141000, C=overflow, L=carry, CC=result. #### CAS addr Compare A and skip If A>[EA]16 then PC=PCIf A=[EA]16 then $PC+1\rightarrow PC$ If A<[EA]16 then $PC+2\rightarrow PC$ If the contents of the A register is greater than the contents of addr, execute the next instruction. If the contents of the A register equals the contents of addr, skip the next location in instruction sequence and execute the instruction at the second location following. If the contents of the A register is less than the contents of addr, skip the next two locations in instruction sequence and execute the instruction at the third location following. **MODES** =SRV, **FORMAT**=MR, **OPCODE**=11, **C**=unchanged, **L**=carry, **CC**=result. #### CAZ Compare A with zero If A>0 then PC=PC If A=0 then PC+1→)PC If A<0 then PC+2→PC If the contents of the A register is greater than zero, execute the next instruction. If the contents of the A register is equal to zero, skip the next location in instruction sequence and execute the instruction at second location following. If the contents of the A register is less than zero, skip the next location in instruction sequence and execute the instruction at third location following. MODES=SRV, FORMAT=GEN, OPCODE=140214, C=unchanged, L=carry, CC=result. ## CHS Change sign $$-A(1)\rightarrow A(1)$$ Complement bit 1 of register A without affecting the rest of the register. MODES=SRV, FORMAT=GEN, OPCODE=140024, C=unchanged, L=unchanged, CC=unchanged. ## CLS addr Compare If L>[EA]32 then PB+1 $\rightarrow$ PB If L=[EA]32 then PB+2 $\rightarrow$ PB If L<[EA]32 then PB+3 $\rightarrow$ PB If the contents of the L register is greater than the contents of addr, execute the next instruction. If the contents of the L register equals the contents of addr, skip the next location in instruction sequence and execute the instruction at second location following. If the contents of the L register is less than the contents of addr, skip next two locations in instruction sequence and execute the instruction at third location following. MODES=V, FORMAT=MR, OPCODE=11 03, C=unchanged, L=carry, CC=result. ## CSA Copy sign of A #### $A(1)\rightarrow C$ -bit; $0\rightarrow A(1)$ Make C equal to bit 1 of register A and clear bit 1 of A without affecting the rest of the register. Used when using single precision arithmetic to do double precision work. MODES =SRV, FORMAT=GEN, OPCODE=140320, C=result, L=unspecified, CC=unchanged. #### DAD addr Double add $$A|B+[EA]31\rightarrow A|B$$ Add the 31-bit integer at addr and addr+1 to the 31-bit integer in registers A|B, and put the result into A|B. If the sum is $\ge 2^{**}30$ or $<-2^{**}30$ , set C; otherwise, clear C. In the first overflow case, the result has a minus sign but a magnitude in positive form equal to the sum minus $2^{**}30$ ; in the second, the result has a plus sign but a magnitude in negative form equal to the sum plus $2^{**}30$ . By definition, bit 1 of the low order word of a 31-bit integer must be 0. The instruction executes only in double precision mode. MODES=SR, FORMAT=MR, OPCODE=06, C= overflow, L=carry, CC=result. #### DBL Enter double precision mode Enter double precision mode. Subsequent LDA, STA ADD and SUB instructions handle 31-bit integers. MODES=SR, FORMAT=GEN, OPCODE=000007, C=unchanged, L=unchanged, CC=unchanged. #### DIV addr Divide #### $A|B/[EA]16\rightarrow A;REM\rightarrow B$ Divide the 31-bit integer in register A|B by the 16-bit integer at addr and put the quotient into A, and the remainder into B. Barring overflow, the results are defined such that A\*[addr]+B equals the original A|B and the remainder in B has the same sign as the dividend. Hence, -42 divided by 5 gives A=-8 and B=-2. Overflow occurs (and the C-bit is set) whenever the quotient is less than -(2\*\*15) or greater than 2\*\*15-1; The A|B register is unchanged. MODES =SR. FORMAT=MR, OPCODE=17, C=overflow, L=unspecified, CC=unspecified. #### DIV addr Divide $$L/[EA]16\rightarrow A;REM\rightarrow B$$ Divide the 32-bit integer in register L by the 16-bit integer at addr and put the quotient into A, and the remainder into B. Barring overflow, the results are defined such that $A^*[addr] + B$ equals the original L and the remainder in B has the same sign as the dividend. Hence, -42 divided by 5 gives A=-8 and B=-2. Overflow occurs (and the C-bit is set) whenever the quotient is less than –(2\*\*15) or greater than 2\*\*15–1. The PIDA instruction is useful for placing 16-bit dividends into L. **MODES**=V, **FORMAT**=MR, **OPCODE**=17, **C**=overflow, **L**=unspecified, **CC**=unspecified. #### DSB addr Double subtract $$A|B-[EA]31\rightarrow A|B$$ Subtract the 31-bit integer at addr and addr+1 from the 31-bit integer in registers A|B, and place the result into A|B. If the difference is $\geq 2^{**}30$ or $<-2^{**}30$ , set C; otherwise, clear C. In the first overflow case, the result has a minus sign but a magnitude in positive form equal to the difference minus $2^{**}30$ ; in the second, the result has a plus sign but a magnitude in negative form equal to the difference plus $2^{**}30$ . Bit 1 of the low order word of a 31-bit integer must be 0. The instruction executes only in double precision mode. To negate one 31-bit integer, simply subtract it from zero. MODES =SR, FORMAT=MR, OPCODE=07, C=overflow, L=carry, CC=result. ## DVL addr Divide long #### $L|E/[EA]32\rightarrow L;REM\rightarrow E$ Divide the 64-bit integer in registers L|E by the 32-bit integer at addr and put the quotient into L, and the remainder into E. Barring overflow, the results are defined such that $L^*[addr] + E$ equals the original L|E and the remainder in E has the same sign as the dividend. Hence, +42 divided by -5 gives L=-8 and E=+2. Overflow occurs (and the C-bit is set) whenever the quotient is less than –(2\*\*31) or greater than 2\*\*31–1. **MODES**=V, **FORMAT**=MR, **OPCODE**=17 03, **C**=overflow, **L**=unspecified, **CC** =unspecified. ## MPL addr Multiply long #### $L^*[EA]32\rightarrow L|E$ Multiply the 32-bit integer in register L by the 32-bit integer at addr, and put the 64-bit integer result into L|E. This operation never overflows because there is always room for the product. **MODES=V**, **FORMAT=MR**, **OPCODE=16** 03, **C=cleared**, **L=unspecified**, **CC=unchanged**. ## MPY addr Multiply #### A\*[EA]16→L Multiply the 16-bit integer in register A by the 16-bit integer at addr, and put the 32-bit integer result into L. This operation never overflows because there is always room for the product. MODES=V, FORMAT=MR, OPCODE=16, C=cleared, L=unspecified, CC=unchanged. ## MPY addr Multiply #### $A*[EA]16\rightarrow A|B$ Multiply the 16-bit integer in register A by the 16-bit integer at addr, and put the 31-bit integer result into registers A and B. If both the multiplier and multiplicand are -2\*\*15 then set C; otherwise clear C. MODES=SR, FORMAT=MR, OPCODE=16, C=cleared, L=unspecified, CC=unchanged. #### NRM Normalize #### A1 A2. . . A16 B1 B2. . . B16 Shift the 31-bit integer in registers A and B left arithmetically, bringing zeros into bit 16 of B, bypassing bit 1 of B, leaving bit 1 of register A unaffected, and dropping bits out of bit 2 of register A until bit 2 of register A is in the state opposite that bit 1 of register A. Since the only data shifted out of bit 2 of register A is equal to the sign, no information is lost. Place the number of shifts performed in bits 9–16 of the keys. **MODES**=SR, **FORMAT**=GEN, **OPCODE**=000101, **C**=unchanged, **L**=unchanged, **CC**=unchanged. #### PID Position for integer divide $$A(2-16) \rightarrow B(2-16); 0 \rightarrow B(1); A(1) \rightarrow A(2-16)$$ Convert the 16-bit integer in register A to a 31-bit integer in A|B by moving the contents of bits 2-16 of register A to bits 2-16 of register B, clearing bit 1 of register B and extending the sign in bit-1 of A through bits 2-16 of A. Intended to allow division of 16-bit A by 16-bit [addr] resulting in two 16-bit integers. 16 in A to 31 in A|B simplifies integer arithmetic. MODES=SR, FORMAT=GEN, OPCODE=000211, C=unchanged, L=unchanged, CC=unchanged. #### PIDA Position for integer divide $$A(1-16) \rightarrow L(17-32); A(1) \rightarrow A(2-16)$$ Convert the 16-bit integer in register A to a 32-bit integer in register L by moving bits 1–16 of A to bits 17–32 of L and extending the sign in bit 1 of A through bits 2–16 of A. **MODES**=V, **FORMAT**=GEN, **OPCODE**=000115, **C**=unchanged, **L**=unchanged, **CC**=unchanged. ## PIDL Position for integer divide-long $$L\rightarrow E; L(1)\rightarrow L(2-32)$$ Convert the 32-bit integer in register L to a 64-bit integer in registers L and E by moving the contents of L to E and extending the sign in bit 1 of L through bits 2-32 of L. PIDL is useful for placing 32 bit operands in L|E. MODES=V, FORMAT=GEN, OPCODE=000305, C= unchanged, L=unchanged, CC=unchanged. #### PIM Position following integer multiply $$B(2-16) \rightarrow A(2-16)$$ Convert the 31-bit integer in registers A|B to a 16-bit integer in A by moving bits 2–16 of B into bits 2–16 of A. MODES=SR, FORMAT=GEN, OPCODE=000205, C=unchanged, L=unchanged, CC=unchanged. ## PIMA Position following integer multiply $$L(17-31) \rightarrow A(1-16)$$ Convert the 32-bit integer in L to a 16-bit integer in register A by moving bits 17-32 of L into bits 1-16 of A. Overflow if a loss of precision would result. MODES=V, FORMAT=GEN, OPCODE=000015, C=overflow, L=unspecified, CC=unspecified. ## PIML Position following integer multiply-long $$L|E(33-64)\rightarrow L(1-32)$$ Convert the 64-bit integer in registers L|E to a 32-bit integer in L by moving bits 33-64 of register L|E into bits 1-32 of register L. Overflow if a loss of precision would result. **MODES** =V, **FORMAT**=GEN, **OPCODE**=000301, **C**=overflow, **L**=unspecified, **CC**=unspecified. #### S1A Subtract one from A #### $A-1\rightarrow A$ Subtract 1 from the 16-bit integer in register A and put the result into A. If the number decremented is -2\*\*15, set C and give a result of 2\*\*15-1; otherwise clear C. MODES=SRV, FORMAT=GEN, OPCODE=140110, C=overflow, L=carry, CC=result. #### S2A Subtract two from A #### $A-2\rightarrow A$ Subtract 2 from the 16-bit integer in register A and put the result into A. If the number decremented is -(2\*\*15-1) or -2\*\*15, set C and give a result of 2\*\*15-1; otherwise clear C. **MODES**=SRV, **FORMAT**=GEN, **OPCODE**=140310, **C**=overflow, **L**=carry, **CC**=result. ## SBL addr Subtract long #### L-[EA]32→L Subtract the 32-bit integer at addr from the 32-bit integer in register L and put the result into the L register. If the difference is greater than +2\*\*31 or less than -2\*\*31, set C; otherwise clear C. In the first overflow case, the result has a minus sign but a magnitude in positive form equal to the difference minus 2\*\*31; in the second, the result has a plus sign but a magnitude in negative form equal to the difference plus 2\*\*31. MODES=V, FORMAT=MR, OPCODE=07 03, C=overflow, L=carry, CC=result. #### SCA Load shift count into A $$keys(9-16) \rightarrow A(9-16); 0 \rightarrow A(1-8)$$ Load the contents of bits 9–16 of the keys into bits 9–16 of register A and clear bits 1–8 of register A. MODES=SR, FORMAT=GEN, OPCODE=000041, C=unchanged, L=unchanged, CC=unchanged. ## SGL Enter single precision mode Return to single precision mode. Subsequent LDA, STA, ADD and SUB instructions handle 16-bit integers. MODES=SR, FORMAT=GEN, OPCODE=000005, C=unchanged, L=unchanged, CC=unchanged. ## SSM Set sign minus #### $1\rightarrow A(1)$ Set bit 1 of register A to one without affecting the rest of the register. MODES=SRV, FORMAT=GEN, OPCODE=140500, C=unchanged, L=unchanged, CC=unchanged. ## SSP Set sign plus #### $0\rightarrow A(1)$ Clear bit 1 of register A without affecting the rest of the register. **MODES**=SRV, **FORMAT** =GEN, **OPCODE**=140100, **C**=unchanged, **L**=unchanged, **CC**=unchanged. ## SUB addr Subtract #### $A-[EA]16\rightarrow A$ Subtract the 16-bit integer at addr from the 16-bit integer in register A and put the result into register A. If the difference is $>2^{**}15$ or $<-2^{**}15$ , set C; otherwise clear C. In the first overflow case, the result has a minus sign but a magnitude in positive form equal to the difference minus $2^{**}15$ ; in the second, the result has a plus sign but a magnitude in negative form equal to the difference plus $2^{**}15$ . MODES=SRV, FORMAT=MR, OPCODE=07, C= overflow, L=carry, CC=result. #### TCA Two's complement A #### $-A \rightarrow A$ Form the two's complement of the contents of register A and put the result into register A. If the number is -2\*\*15, set C and give a result of -2\*\*15; otherwise clear C. **MODES**=SRV, **FORMAT**=GEN, **OPCODE**=140407, **C**=overflow, **L**=carry, **CC**=result. #### TCL Two's complement long $-L \rightarrow L$ Form the two's complement of the contents of register L and put the result into L. If the result is -2\*\*31, set C and give a result of -2\*\*31; otherwise clear C. **MODES**=V, **FORMAT**=GEN, **OPCODE**=141210, **C**=overflow, **L**=carry, **CC**=result. ## INTEGRITY CHECK FOR HARDWARE—INTGY ## EMCM Enter machine check mode In machine check mode the microprogram responds to a machine parity error by causing a machine check interrupt if there is a non-zero vector in the interrupt location. If this location is zero the machine halts. MODES=SRV, FORMAT=GEN, OPCODE=000503, C=unchanged, L=unchanged, CC=unchanged. Restricted instruction. ## LMCM Leave machine check mode A machine parity error sets the machine check flag, but does not cause a check (V-mode) or generate an interrupt (SR-mode). MODES=SRV, FORMAT=GEN, OPCODE=000501, C=unchanged, L=unchanged, CC=unchanged. Restricted instruction. ## MDEI Memory diagnostic enable interleave Enable the memory interleave capability. MODES=V, FORMAT=GEN, OPCODE=001304, C =unchanged, L=unchanged, CC=unchanged. Restricted instruction. ## MDII Memory diagnostic inhibit interleave Inhibit the memory diagnostic interleave capability. MODES=V, FORMAT=GEN, OPCODE =001305, C=unchanged, L=unchanged, CC=unchanged. Restricted instruction. ## MDIW Memory diagnostic write interleaved Write interleaved memory. MODES=V, FORMAT=GEN, OPCODE=001324, C=unchanged, L=unchanged, CC=unchanged. Restricted instruction. ## MDRS Memory diagnostic read syndrome bits Read memory syndrome bits. MODES=V, FORMAT=GEN, OPCODE=001306, C=unchanged, L=unchanged, CC=unchanged. Restricted instruction. ## MDWC Memory diagnostic write control register Write memory control register. MODES=V, FORMAT=GEN, OPCODE=001307, C=unchanged, L=unchanged, CC=unchanged. Restricted instruction. ## RMC Clear machine check Clear the machine check flag. MODES=SRV, FORMAT=GEN, OPCODE-000021, C=unchanged, L=unchanged, CC=unchanged. Restricted instruction. ## SMCR Skip on machine check reset If the machine check flag is zero (indicating no machine detected parity error), skip the next instruction in sequence. (When the processor is in machine check mode, this instruction has no meaning and executes as a skip). MODES=SRV, FORMAT=GEN, OPCODE=100200, C=unchanged, L=unchanged, CC=unchanged. ## SMCS Skip on machine check set If the machine check flag is set (indicating a machine detected parity error), skip the next instruction in sequence. (When the processor is in machine check mode, this instruction has no meaning and executes as a NOP). MODES=SRV, FORMAT=GEN, OPCODE=101200, C= unchanged, L=unchanged, CC=unchanged. ## VIRY Verify Execute the verification routine, and if there is a failure of any kind, go on to the next instruction with the number of the test that failed in register A. If there are no errors, skip the next instruction in sequence. If the processor does not have the verification routine, this instruction executes as no-op. **MODES**=SRV, **FORMAT**=GEN, **OPCODE**=000311, **C**=unspecified, **L**=unspecified, **CC**=unspecified. Restricted instruction. ## XVRY Verify the XIS board (Prime 500) Executes a Prime 500 microcode diagnostic routine that checks the integrity of the XIS board. If the XIS board is not functional, the machine will not skip the next instruction and the A register will hold the failed micro-diagnostic test number. If the machine passes the verify instruction, the next instruction is skipped. MODES=V, FORMAT=GEN, OPCODE=001113, C=unspecified, L=unspecified, CC=unspecified. Restricted instruction. The codes and tests are: - '72 Data Move Test—Load and Unload XIS Board - '73 Normalize Test—Adjust Test - '74 Binary Multiply - '75 Binary Divide - '76 Decimal Arithmetic #### INPUT/OUTPUT-I/O ## CAI Clear active interrupt Terminate the presently active interrupt so that the processor can recognize interrupt requests from devices of lower priority (in higher slots) than the device for which the current interrupt is being held. This instruction is effective only in vectored interrupt mode. MODES=SRV, FORMAT=GEN, OPCODE=000411, C=unchanged, L=unchanged, CC=unchanged. Restricted instruction. ## EIO addr Execute I/O Perform the I/O instruction represented by the effective address, e.g., X='04 EIO '131000,X will execute an INA with FUNC = '10 and DEV = '04. EQ = successful INA, OTA or SKS, NE = unsuccessful INA, OTA or SKS. OCP always successful, sets NE. MODES=V, FORMAT= MR, OPCODE=14 01, C=unchanged, L=unchanged, CC=result. Restricted instruction. #### **ENB** Enable interrupt Enable the external interrupt system so the processor will respond to interrupt requests over the I/O bus. This instruction takes effect following execution of the next sequential instruction. MODES=SRV, FORMAT=GEN, OPCODE=000401, C=unchanged, L=unchanged, CC=unchanged. Restricted instruction. ## ESIM Enter standard interrupt mode Enter standard interrupt mode so that all interrupts are made through location '63. MODES =SRV, FORMAT=GEN, OPCODE=000415, C=unchanged, L=unchanged, CC=unchanged. Restricted instruction. ## **EVIM** Enter vectored interrupt mode Enter vectored interrupt mode so that the interrupt priority of a device is determined by its position on the I/O bus (with lower devices having higher priority) and each interrupt is made through the location specified by the interrupting device. MODES=SRV, FORMAT=GEN, OPCODE=000417, C=unchanged, L=unchanged, CC=unchanged. Restricted instruction. ## INA FUNC|DEV Input to A Input data from device DEV into register A. FUNC determines the type of data. If the device does not respond ready, then do not perform the transfer, but execute the next instruction in sequence. If the device responds ready, then perform the transfer specified by FUNC and skip the next instruction in sequence. To perform the function specified by FUNC, the processor reads the information from DEV into register A and performs whatever control operations are appropriate to the function and the device. Depending on FUNC, the information read may be data, status, an address, a word count, or anything else. The number of bits brought into register A depends on the type of information, the size of the device register, the mode of operation, etc. INA instructions for any device except device '20 use a ready test and skip the next instruction if the device was ready. MODES=SR, FORMAT=PIO, OPCODE=54, C=unchanged, L=unchanged, CC=unchanged. Restricted instruction. ## INH Inhibit interrupts Inhibit the external interrupt system so the processor will not respond to interrupt requests over the I/O bus. This instruction takes effect immediately. MODES=SRV, FORMAT=GEN, OPCODE=001001, C=unchanged, L=unchanged, CC=unchanged. Restricted instruction. ## OCP FUNC DEV Output control pulse Send a control pulse for the function specified by FUNC (bits 7–10) to the device specified by DEV (bits 11–16). This instruction never skips and is used for such functions as initializing a disk controller, or starting a transfer. MODES=SR, FORMAT=PIO, OPCODE=14, C= unchanged, L=unchanged, CC=unchanged. Restricted instruction. ## OTA FUNCIDEV Out from A Transfer data from register A to DEV. FUNC tells the device which operation to perform. If the device does not respond ready, then do not perform the transfer but instead execute the next instruction in sequence. If the device responds ready, then perform the transfer and skip the next instruction in sequence. The processor sends the contents of register A to DEV which performs whatever control operations are appropriate to the function and the device. The number of bits actually accepted by the device depends on the type of information, the size of the device register, the mode of operation, etc. The contents of register A are unaffected. An OTA instruction for any device except device '20 uses a ready test and the skipping procedure as stated in the description of the instruction. An OTA to device '20 makes no test and does not skip. MODES=SR, FORMAT=PIO, OPCODE=74, C=unchanged, L=unchanged, CC=unchanged. Restriction instruction. ## SKS FUNC|DEV Skip if satisfied FUNC (bits 7–10) defines a condition to be tested by the SKS. When the condition is satisfied, the device specified by DEV (bits 11–16) responds ready, and the next instruction in sequence is skipped. MODES=SR, FORMAT=PIO, OPCODE=34, C=unchanged, L=unchanged, CC=unchanged. Restriction instruction. #### KEY MANIPULATION—KEYS See Section 9 for the format of the keys. #### INK Input keys Read the keys into register A. MODES=SR, FORMAT=GEN, OPCODE=000043, C=unchanged, L=unchanged, CC=unchanged. #### OTK Output keys #### A→keys Set up the keys from the contents of register A. Each bit position in register A corresponds to the bit position in the keys, e.g., bit 1 of register A becomes the C-bit in the keys. **MODES** =SR, **FORMAT**=GEN, **OPCODE**=000405, **C**=loaded by instruction, **L**=loaded by instruction. #### RCB Reset C-bit $0\rightarrow C$ Clear the C-bit in the keys. **MODES**=SRV, **FORMAT**=GEN, **OPCODE**=140200, **C**=cleared, **L** =unspecified, **CC**=unchanged. #### SCB Set C-bit 1**→**C Set the C-bit in the keys. MODES=SRV, FORMAT=GEN, OPCODE=140600, C=set, L=unspecified, CC=unchanged. #### TAK Transfer A to keys #### A→keys Transfer the contents of register A to the keys register. If the new value of the keys specifies a different addressing mode, note that the new mode takes effect on the next instruction. **MODES=V**, **FORMAT=GEN**, **OPCODE=001015**, **C=loaded** by instruction, **CC=loaded** by instruction. #### TKA Transfer keys to A #### keys→A Transfer the contents of the keys register to register A. MODES=V, FORMAT=GEN, OPCODE=001005, C=unchanged, L=unchanged, CC=unchanged. #### LOGICAL OPERATIONS—LOGIC #### ANA addr AND to A #### A.AND.[EA]16→A AND the contents of location addr with the contents of register A and place the result in register A. A given bit of the result is 1 if the corresponding bits of both operands are 1; otherwise the resulting bit is 0. | A BIT | Memory Bit | Resulting Bit | |-------|------------|---------------| | 0 | 0 | 0 | | 0 | 1 | 0 | | 1 | 0 | 0 | | 1 | 1 | 1 | MODES=SRV, FORMAT=MR, OPCODE=03, C=unchanged, L=unchanged, CC=unchanged. #### ► ANL addr AND long #### L.AND.[EA]32→L AND the contents of register L with the 32-bit quantity at addr, putting the result in L. MODES=V, FORMAT=MR, OPCODE=03 03, C=unchanged, L=unchanged, CC=unchanged. ## CMA Complement A #### NOT. $A \rightarrow A$ Form the ones complement of the contents of register A and put the result in register A. Each one becomes a zero; each zero becomes a one. MODES=SRV, FORMAT=GEN, OPCODE=140401, C=unchanged, L=unchanged, CC=unchanged. #### ERA addr Exclusive OR to A #### A.XOR.[EA]16→A EXCLUSIVE OR the contents of location addr with the contents of register A and place the result in register A. A given bit of the result is 1 if the corresponding bits of the operands differ; otherwise the resulting bit is 0. | A BIT | Memory Bit | Resulting Bit | |-------|------------|---------------| | 0 | 0 | 0 | | 0 | 1 | 1 | | 1 | 0 | 1 | | 1 | 1 | 0 | MODES=SRV, FORMAT=MR, OPCODE=05, C=unchanged, L=unchanged, CC=unchanged. ## ERL addr Exclusive OR long #### L.XOR.[EA]32→L EXCLUSIVE OR the contents of register L with the 32-bit quantity at addr, putting the result in L. MODES=V, FORMAT=MR, OPCODE=05 03, C=unchanged, L=unchanged, CC=unchanged. #### ORA Inclusive OR #### A.OR.[EA]16 $\rightarrow$ )A INCLUSIVE OR the contents of register A with the 16-bit quantity at addr, putting the result in A. MODES=V, FORMAT=MR, OPCODE=03 02, C=unchanged, L=unchanged, CC=unchanged. #### LOGICAL TEST AND SET—LTSTS If the test is satisfied, then set the A register equal to 1. If the test is not satisfied, then set the register equal to 0. These instructions simplify the analysis of complex logical expressions. $$\begin{array}{c} A \ \text{Register (Blank)} \\ \text{Condition Code (C)} \\ \text{L Register (L)} \\ \text{Floating Point (F)} \\ \text{Register} \end{array} \right) \quad \begin{array}{c} LT \\ \text{LE} \\ \text{EQ} \\ \text{NE} \\ \text{GE} \\ \text{GT} \end{array} \right)$$ #### A-Register test | Mnemonic | Function | Opcode | |----------|-----------------------------------------------------------------|--------| | LLT | If $A < 0$ , then $1 \rightarrow A$ ; else $0 \rightarrow A$ | 140410 | | LLE | If $A \leq 0$ , then $1 \rightarrow A$ ; else $0 \rightarrow A$ | 140411 | | LEQ | If $A = 0$ , then $1 \rightarrow A$ ; else $0 \rightarrow A$ | 140413 | | LNE | If $A \neq 0$ , then $1 \rightarrow A$ ; else $0 \rightarrow A$ | 140412 | | LGE | If $A \ge 0$ , then $1 \rightarrow A$ ; else $0 \rightarrow A$ | 140414 | | LGT | If $A > 0$ , then $1 \rightarrow A$ ; else $0 \rightarrow A$ | 140415 | $MODES = SRV, \ FORMAT = GEN, \ C = unchanged, \ L = unchanged, \ CC = result.$ #### Condition code test | Mnemonic | Function | Opcode | |----------|-----------------------------------------------------------------|--------| | LCLT | If $CC < 0$ , then $1 \rightarrow A$ ; else $0 \rightarrow A$ | 141500 | | LCLE | If $CC \leq 0$ , then $1\rightarrow A$ ; else $0\rightarrow A$ | 141501 | | LCEQ | If $CC = 0$ , then $1 \rightarrow A$ ; else $0 \rightarrow A$ | 141503 | | LCNE | If $CC \neq 0$ , then $1\rightarrow A$ ; else $0\rightarrow A$ | 141502 | | LCGE | If $CC \ge 0$ , then $1 \rightarrow A$ ; else $0 \rightarrow A$ | 141504 | | LCGT | If $CC > 0$ , then $1 \rightarrow A$ ; else $0 \rightarrow A$ | 141505 | $\label{eq:modes} \textbf{MODES}\!\!=\!\!\mathrm{V}, \ \textbf{FORMAT}\!\!=\!\!\mathrm{GEN}, \ \textbf{C}\!\!=\!\!\mathrm{unchanged}, \ \textbf{L}\!\!=\!\!\mathrm{unchanged}, \ \textbf{CC}\!\!=\!\!\mathrm{unchanged}.$ ## L register test | Mnemonic | Function | Opcode | |----------|----------------------------------------------------------------------|--------| | LLLT | If $L < 0$ , then $1 \rightarrow A$ ; else $0 \rightarrow A$ | 140410 | | LLLE | If $L \leq 0$ , then $1\rightarrow A$ ; else $0\rightarrow A$ | 141511 | | LLEQ | If $L = 0$ , then $1 \rightarrow A$ ; else $0 \rightarrow A$ | 141513 | | LLNE | If $L \neq 0$ , then $1 \rightarrow A$ ; else $0 \rightarrow A$ | 141512 | | LLGE | If $L \geqslant 0$ , then $1 \rightarrow A$ ; else $0 \rightarrow A$ | 140414 | | LLGT | If $L > 0$ , then $1 \rightarrow A$ ; else $0 \rightarrow A$ | 141515 | $MODES = V, \ FORMAT = GEN, \ C = unchanged, \ L = unchanged, \ CC = result.$ #### Floating register test | Mnemonic | Function | Opcode | |----------|-----------------------------------------------------------------|--------| | LFLT | If $F < 0$ , then $1 \rightarrow A$ ; else $0 \rightarrow A$ | 141110 | | LFLE | If $F \leq 0$ , then $1 \rightarrow A$ ; else $0 \rightarrow A$ | 141111 | | LFEQ | If $F = 0$ , then $1 \rightarrow A$ ; else $0 \rightarrow A$ | 141113 | | LFNE | If $F \neq 0$ , then $1\rightarrow A$ ; else $0\rightarrow A$ | 141112 | | LFGE | If $F \ge 0$ , then $1 \rightarrow A$ ; else $0 \rightarrow A$ | 141114 | | LFGT | If $F > 0$ , then $1 \rightarrow A$ ; else $0 \rightarrow A$ | 141115 | MODES=V, FORMAT=GEN, C=unchanged, L=unchanged, CC=result. ## LT Logic set A true 1*→*A Set A equal to one. MODES=SRV, FORMAT=GEN, OPCODE=140417, C=unchanged, L=unchanged, CC=result. #### LF Logic set A false $0\rightarrow A$ Set A equal to zero. MODES=SRV, FORMAT=GEN, OPCODE=140416. C=unchanged, L=unchanged, CC=result. #### MACHINE CONTROL—MCTL ## CXCS Control extended control store Move the A register to control register on writable control store board. MODES=V, FORMAT=GEN, OPCODE=001714, C=unspecified, L=unspecified, CC=unspecified. Restricted instruction. ## EPMJ addr Enter paging mode and jump (Prime 300) EA→PC EPMJ is a two-word instruction. The first word is the opcode; the second word contains a 16-bit address pointing to the final effective address which is transferred to the program counter; the associative memory registers are cleared, and paging mode is enabled. MODES =SR, FORMAT=MR, OPCODE=000217, C=unchanged, L=unchanged, CC=unchanged. Restricted instruction. ## **EPMX addr** Enter paging mode and jump to XCS (Prime 300) EA→PC EPMX is a two-word instruction. The first word is the opcode; the second word contains a 16-bit pointer to the location of the micro-instruction. Paging is enabled. **MODES**=SR, **FORMAT**=MR, **OPCODE**=000237, **C**=unchanged, **L**=unchanged, **CC**=unchanged. Restricted instruction. ## ERMJ addr Enter restricted execution mode and jump (Prime 300) EA→PC ERMJ is a two-word instruction. The first word is the opcode; the second word contains a 16-bit address pointing to the final effective address which is transferred to the program counter; restricted execution mode is enabled, and interrupts are enabled. MODES=SR, FORMAT=MR, OPCODE=000701, C=unchanged, L=unchanged, CC=unchanged. Restricted instruction. ## ERMX addr Enter restricted execution mode and jump to XCS (Prime 300) EA→PC ERMX is a two-word instruction. The first is the opcode. The second word contains a 16-bit pointer to the location of the micro-instruction. Restricted execution mode and interrupts are enabled. MODES=SR, FORMAT=MR, OPCODE=000721, C=unchanged, L=unchanged, CC=unchanged. Restricted instruction. #### EVMJ addr Enter virtual mode and jump (Prime 300) EA→PC EVMJ is a two-word instruction. The first word, which has the effect of an EPMJ and ERMJ combined, is the opcode; the second word contains a 16-bit address pointing to the final effective address which is transferred to the program counter. Paging, interrupts, and restricted execution mode are enabled. MODES=SR, FORMAT=MR, OPCODE=000703, C= unchanged, L=unchanged, CC=unchanged. Restricted instruction. ## EVMX addr Enter virtual mode and jump (Prime 300) EA→PC EVMX is a two-word instruction. The first word, which has the effect of an EPMX and ERMX combined, is the opcode; the second word contains a 16-bit pointer to the location of the micro-instruction. Paging, interrupts, and restricted execution mode are enabled. MODES= SR, FORMAT=GEN, OPCODE=000000, C=unchanged, L=unchanged, CC=unchanged. Restricted instruction. #### HLT Halt Halt the processor with the STOP indicator lit on the control panel and the program counter pointing to the next instruction in sequence (the instruction that would have been executed had the HLT been replaced by a no-op). The data lights display the next instruction. **MODES** =SRV, FORMAT=GEN, OPCODE=000000, C=unchanged, L=unchanged, CC=unchanged. Restricted instruction. ## ► ITLB Invalidate STLB entry Invalidate the Segmentation Translation Lookaside Buffer (STLB) entry whose address is in L. This instruction must be executed whenever the page table entry for the given address is changed. If a Segment Descriptor Word (SDW) or a Descriptor Table Address Register (DTAR) is changed, usually the entire STLB must be invalidated. This can be done by executing ITLB once for each page of any single segment (except segment 0). If the segment number portion of L is zero, the I/O TLB entry corresponding to address L is invalidated. **MODES**=V, **FORMAT**=GEN, **OPCODE**=000615, **C**=unchanged, **L**=unchanged, **CC**=unchanged. Restricted instruction. #### ► LIOT addr Load I/O TLB Load the I/O Translation Lookaside Buffer with the following information: 1. Virtual address (VA) in segment 0. This is provided by the effective - address computed from the address pointer, addr. - 2. Physical address (PA) which is the translation of the virtual address. This is obtained by the processor from segment 0. If the fault bit is set, a page fault will be generated. - 3. Target virtual address (TVA) which is the segment number and page number of the virtual address that will be used by procedures accessing this information. This will be used to help invalidate the proper locations in the cache. This is provided in the L register as a virtual address. The low order 10 bits (word number in page) and the segment number are ignored. #### Summary: | Information | Source | |-------------|---------------------------| | VA | AP | | PA | Segment number page table | | TVA | L | **MODES**=V, **FORMAT**=AP, **OPCODE**=000044, **C**=unspecified, **L**=unspecified, **CC**=unspecified. Restricted instruction. #### ► LPID Load process ID A→RPID Load the process id register from bits 1-12 of Register A. MODES=V, FORMAT=GEN, OPCODE=000617, C=unchanged, L=unchanged, CC=unchanged. Restricted instruction. ## ► LPMJ addr Leave paging mode and jump (Prime 300) EA→PC LPMJ is a two-word instruction. The first word is the opcode; the second word contains a 16-bit address pointing to the final effective address which is transferred to the program counter. Paging mode is disabled. MODES=SR, FORMAT=MR, OPCODE=000215, C=unchanged, L=unchanged, CC=unchanged. Restricted instruction. ## ▶ LPMX addr Leave paging mode and jump to XCS (Prime 300) EA→PC LPMX is a two-word instruction. The first word is the opcode. The second word contains a 16-bit pointer to the location of the micro-instruction. Paging is disabled. MODES=SR, FORMAT=MR, OPCODE=000235, C=unchanged, L=unchanged, CC=unchanged. ## LPSW addr Load program status word Load Program Status Word is a restricted operation which can change the status of the processor. It can be executed only in ring zero. The instruction addresses a four-word block at location addr containing a program counter (ring, segment, and word numbers) in the first two words, keys in the third word and modals in the fourth. The program counter and keys of the running process are loaded from the first three words, then the processor modals are loaded from the fourth. If the new keys have the in-dispatcher bit (bit 16) off, the current process continues in execution but at a location defined by the new program counter. If the new keys have the in-dispatcher bit on, the dispatcher is entered to dispatch the highest priority ready process. Whenever the current process again becomes the highest priority ready process, it will then resume execution at the point defined by its new program counter. The modals are associated with the processor and not the process, so in either case, the new modals are effective immediately. This instruction is used to load the four words of the register set which cannot be correctly loaded with the STLR instruction: the program counter (ring, segment, and word number), the keys, and the modals. The STLR instruction should not be used to set these words, as it does not update the separate hardware registers in which the processor maintains duplicate information to achieve higher performance. The LPSW instruction must never attempt to change the current-register-set bits of the modals (bits 9–11). This implies that, unless for some reason the current register set in effect for the execution of the program is known with certainty, any program wishing to execute an LPSW must inhibit interrupts (to prevent an unexpected process and register exchange), read the register set currently in effect from the present modals (as with an LDLR '24), mask those register-set bits into the modals to be loaded, and then finally execute the LPSW. Fortunately, in both usual applications of LPSW the needed register-set bits are predictable: when LPSW is first used after Master Clear to turn on process-exchange mode, the current-register-set bits should be 010 (the processor is always initialized to register set 2); and when LPSW is used to return from a fault, check, or interrupt handled by inhibited code, whatever register-set bits were stored away by the fault, check, or interrupt are still correct and can simply be reloaded. Similarly, except to load status correctly stored on a fault, check, or interrrupt, and LPSW should never attempt to set either the save-done bit (bit 15) or the in-dispatcher bit (bit 16) of the keys. The initial LPSW following a Master Clear should have both these bits off. MODES=V, FORMAT=AP, OPCODE=000711, C=loaded by instruction, L=loaded by instruction, CC=loaded by instruction. #### LWCS Load writable control store Load writable control store portion of extended control store board from the memory block pointed to by XB. The control register loaded by CXCS modifies this instruction. **MODES**= V, **FORMAT**=GEN, **OPCODE**=001710, **C**=unspecified, **L**=unspecified, **CC**=unspecified. Restricted instruction. #### MIA addr Microcode indirect A Microcode entrance. **MODES**=V, **FORMAT**=MR, **OPCODE**=12 01, **C**=unchanged, **L**=unchanged, **CC**=unchanged. #### MIB addr Microcode indirect B Microcode entrance. MODES=V, FORMAT=MR, OPCODE=13 01, C=unchanged, L=unchanged, CC=unchanged. ## NOP No operation PC+1→PC Do nothing, but go on to the next instruction. MODES=SRV, FORMAT=GEN, OPCODE=000001, C=unchanged, L=unchanged, CC=unchanged. ## PTLB Purge TLB Purge either the entire non I/O Translation Lookaside Buffer (TLB) or a specified physical page. The physical page number is provided right-justified in the L register. The high-order bit of L is set to indicate a complete purge. MODES=V, FORMAT=GEN, OPCODE=000064, C=unspecified, L=unspecified, CC=unspecified. Restricted instruction. #### RRST addr Restore registers Restore the general, floating and XB registers from the save area starting at location addr. The format of the save area is as for RSAV below. **MODES**=V, **FORMAT**=AP, **OPCODE**= 000717, **C**=unchanged, **L**=unchanged, **CC**=unchanged. ## RSAV addr Save registers Save the general, floating and XB registers in the save area starting at location addr. Only those general and floating point registers which are not zero are saved. A save mask is generated which identifies the registers which are not zero. With the exception of XB, which is always saved, registers which are zero are not stored into the save area; their location remains untouched. The format of the RSAV area is: | Word | Contents | |-------|-------------| | 1 | Save Mask | | 2-5 | FALR1 (FAC) | | 6-9 | FALR 0 | | 10 | X | | 11-13 | _ | | 14 | Y,S | | 15-17 | | | 18-19 | E | | 20 | A,LH | | 21 | B,LL | | 22-25 | _ | | 26-27 | XB | Save Mask: | MUST BE ZERO | FALR 1, FAC | FALR 0 | X | | Y, S | | Ε | L, B, A | | |--------------|-------------|--------|---|----|------|----|----|---------|-------| | 1 – 4 | 5 — 6 | 7 — 8 | 9 | 10 | 11 | 12 | 13 | 14 | 15-16 | The size of the RSAV area is 27 words. **MODES**=V, **FORMAT**=AP, **OPCODE**=000715, **C**= unchanged, **L**=unchanged, **CC**=unchanged. ## > STPM Store processor model number Store the CPU model number and microcode revision number in an eight-word field pointed to by the temporary base register (XB). The first 32-bit field will define the processor model number. This field will not be modified on any P400 or P500 since STPM executes as a SGL which is similar to a NOP. Thus the program is required to put a zero into this field prior to executing the STPM. The following long-integer codes are assigned: | 0L | P400, P500 | |----|------------| | 3L | P350 | | 4L | P450 | | 5L | P550 | | 6L | P650 | | 7L | P750 | The second 32-bit field will define the microcode revision. It will be a unique number that changes at each revision. The P400 and P500 do not implement this. The remaining 64-bits are reserved for future expansion. The recommended sequence for the STPM is: EAXB Memory Buffer CRL STL XB% STPM **MODES**=V, **FORMAT**=GEN, **OPCODE**=000024, **C**=unchanged, **L**=unchanged, **CC**=unchanged. Restricted instruction. #### SVC Supervisor call An addressing mode independent method of making an operating system request. It is also independent of operating system. The call protocol is such that an operation code (request) followed by argument pointers (the 16-bit word number—on the Prime 400/500, segment number is the segment in which the SVC resides) is made available to the operating system. PRIMOS has defined a uniform set of operation codes to provide operating system independent services. #### Note On the Prime 100-300 (and on the segmented CPU's in non process exchange mode), the SVC is treated as an interrupt. On the segmented CPU's, the SVC is treated as a fault with offset '14. $\label{eq:modes} \textbf{MODES} \!\!=\!\! \text{SRV, FORMAT} \!\!=\!\! \text{GEN, OPCODE} \!\!=\!\! 000505, \ \textbf{C} \!\!=\!\! \text{unchanged, L} \!\!=\!\! \text{unchanged, CC} \!\!=\!\! \text{unchanged.}$ #### WCS Writable control store Reserved set of 64 op codes to serve as microcode entrances. **MODES**=RV, **FORMAT**=GEN, **OPCODE**=0016xx, **C**=unchanged, **L**=unchanged, **CC**=unchanged. #### MOVE DATA—MOVE #### DLD addr Double load #### $[EA]32\rightarrow A|B$ Load the contents of location addr into register A and the contents of location addr+1 into register B. This instruction executes only in double precision mode. MODES=SR, FORMAT =MR, OPCODE=02, C=unchanged, L=unchanged, CC=unchanged. #### DST addr Double store #### $A|B\rightarrow [EA]32$ Store the contents of register A in location addr and the contents of register B in location addr+1. This instruction executes only in double precision mode. MODES=SR, FORMAT=MR, OPCODE=04, C=unchanged, L=unchanged, CC=unchanged. #### ► IAB Interchange the A and B registers A⇔B Move the contents of register A to register B and the contents of register B to register A. **MODES**=SRV, **FORMAT**=GEN, **OPCODE**=000201, **C**=unchanged, **L**=unchanged, **CC**=unchanged. ## ICA Interchange characters in A $$A(1-8) \Leftrightarrow A(9-16)$$ Move the contents of register A bits 1–8 to bits 9–16 and the contents of bits 9–16 to bits 1–8. **MODES**=SRV, **FORMAT**=GEN, **OPCODE**=141340, **C**=unchanged, **L**=unchanged, **CC**=unchanged. ## ► ICL Interchange and clear left $$A(1-8) \rightarrow A(9-16); 0 \rightarrow A(1-8)$$ Move the contents of register A bits 1-8 to bits 9-16 and then clear the left byte (bits 1-8). **MODES**=SRV, **FORMAT**=GEN, **OPCODE**=141140, **C**=unchanged, **L**=unchanged, **CC**=unchanged. #### ► ICR Interchange and clear right $$A(9-16) \rightarrow A(1-8); 0 \rightarrow A(9-16)$$ Move the contents of register A bits 9–16 to bits 1–8 and clear the right byte (bits 9–16). The original contents of bits 1–8 are lost. **MODES**=SRV, **FORMAT**=GEN, **OPCODE**=141240, **C**= unchanged, **L**=unchanged, **CC**=unchanged. ## ► ILE Interchange L and E L⇔E Move the contents of register L to register E and the contents of register E to register L. **MODES**=V, **FORMAT**=GEN, **OPCODE**=141414, **C**=unchanged, **L**=unchanged, **CC**=unchanged. ## IMA addr Interchange memory and the A register Store the contents of the A register in location addr and load the original contents of location addr into the A register. **MODES**=SRV, **FORMAT**=MR, **OPCODE**=13, **C**=unchanged, **L**= unchanged, **CC**=unchanged. ## LDA addr Load the A register [EA]16→A Load the contents of location addr into the A register. MODES=SRV, FORMAT=MR, OPCODE=02, C=unchanged, L=unchanged, CC=unchanged. ## ▶ LDL addr Load long [EA]32→L Move the 32-bit quantity at location addr to register L. **MODES**=V, **FORMAT**=MR, **OPCODE** =02 03, **C**=unchanged, **L**=unchanged, **CC**=unchanged. #### LDLR addr Load L from addressed register register(EA)W→L Copy the contents of the register specified by the word number portion of addr into L. There are three cases of this instruction which are summarized below. Only the word portion of the effective address, (EA)W, is used. Bit 2 of (EA)W = 1; Ignore Bits 1 and 3-9: (EA)W(10-16) - Absolute register number from 0-'177. Restricted instruction. Bit 2 of (EA)W = 0: (EA)W(13-16) - Register 20-'37 in the current register set. Restricted instruction. Bit 12 of (EA)W = 0: (EA)W(13-16) - Register 0-'17 in the current register set. MODES=V, FORMAT=MR, OPCODE=05 01, C=unchanged. L=unchanged, CC=unchanged. #### LDX addr Load X [EA]16→X Load the contents of location addr into the X register. The contents of addr are unaffected, the previous contents of the X register are lost. This instruction cannot itself specify indexing, although an address word retrieved in the effective address calculation may do so in 16S mode. MODES=SRV, FORMAT=MR, OPCODE=35, C=unchanged, L=unchanged, CC =unchanged. #### LDY addr Load Y [EA]32→Y Move the 16 bit quantity at location addr to register Y. Cannot be indexed. MODES=V, FORMAT=MR, OPCODE=35 01, C=unchanged, L=unchanged, CC=unchanged. ## STA addr Store the A register $A \rightarrow [EA]16$ Store the contents of the A register in location addr. The contents of the A register are unaffected; the previous contents of addr are lost. MODES=SRV, FORMAT=MR, OPCODE =04, C=unchanged, L=unchanged, CC=unchanged. ## STAC addr Store A conditionally If [EA]16=B then $A\rightarrow [EA]16$ Store the contents of A into location addr, if and only if, the contents of location addr equals the contents of B. The comparison and store are guaranteed not to be separated by the execution of any other instructions. That is, it is not possible for any other instruction to change the contents of the addressed memory word after the comparison has been made but before the store takes place. The condition-code bits are set "equal" if the store takes place, otherwise "unequal". MODES=V, FORMAT=AP, OPCODE=001200, C=unchanged, L=unchanged, CC=result. ## ► STL addr Store long L→[EA]32 Store the contents of register L into the 32-bit long word at location addr. MODES=V, FORMAT=MR, OPCODE=04 03, C=unchanged, L=unchanged, CC=unchanged. #### ▶ STLC addr Store L conditionally If [EA]32=E then $L\rightarrow [EA]32$ Store the contents of L into the 32-bit location at addr if and only if the contents of location addr equals the contents of E. STLC and STAC are provided to aid cooperating sequential processes in the manipulation of shared data. They often permit removal of mutually exclusive critical sections, hence possibly indefinite delays, from algorithms which would otherwise have required them. Both of these instructions are interlocked against direct-memory input /output. Hence, these instructions may be used to interlock a process with a DMA, DMC or DMQ channel, or to interlock a memory location possibly being accessed by I/O. MODES=V, FORMAT=AP, OPCODE=001204, C=unchanged, L=unchanged, CC=result. #### STLR addr Store L into addressed register L→register (EA)W Store the contents of L into the register location specified by addr. There are three cases of this instruction which are summarized under LDLR. Only the word portion of the effective address, ((EA)W), is used. MODES=V, FORMAT=MR, OPCODE=03 01, C=unchanged, L= unchanged, CC=unchanged. #### ► STX addr Store X register $X\rightarrow [EA]16$ Store the contents of the X register in location addr. The contents of the X register are unaffected and the previous contents of addr are lost. This instruction cannot itself specify indexing, although an address word retrieved in the effective address calculation may do so in 16S mode. MODES=SRV, FORMAT=MR, OPCODE=15, C=unchanged, L=unchanged, CC =unchanged. #### STY addr Store Y $Y\rightarrow [EA]32$ Store the contents of Y into the location specified by addr. Cannot be indexed. MODES=V, FORMAT=MR, OPCODE=35 02, C=unchanged, L=unchanged, CC=unchanged. #### TAB Transfer A to B A→B Move the contents of A to B. **MODES**=V, **FORMAT**=GEN, **OPCODE**=140314, **C**=unchanged, **L**=unchanged, **CC**=unchanged. #### TAX Transfer A to X $A \rightarrow X$ Move the contents of A to X. **MODES**=V, **FORMAT**=GEN, **OPCODE**=140504, **C**=unchanged, **L**=unchanged, **CC**=unchanged. #### TAY Transfer A to Y A→Y Move the contents of A to Y. **MODES**=V, **FORMAT**=GEN, **OPCODE**=140505, **C**=unchanged, **L**=unchanged, **CC**=unchanged. #### TBA Transfer B to A $B \rightarrow A$ Move the contents of B to A. MODES=V, FORMAT=GEN, OPCODE=140604, C=unchanged, L=unchanged, CC=unchanged. #### TXA Transfer X to A $X \rightarrow A$ Move the contents of X to A. **MODES**=V, **FORMAT**=GEN, **OPCODE**=141034, **C**=unchanged, **L**=unchanged, **CC**=unchanged. #### TYA Transfer Y to A Y→A Move the contents of Y to A. MODES=V, FORMAT=GEN, OPCODE=141124, C=unchanged, L=unchanged, CC=unchanged. ## XCA Exchange and clear the A register $A \rightarrow B \cdot 0 \rightarrow A$ Exchange (swap) the A and B registers; then clear A. MODES=SRV, FORMAT=GEN, OPCODE=140104, C=unchanged, L=unchanged, CC=unchanged. ## XCB Exchange and clear the B register $B \rightarrow A: 0 \rightarrow B$ Exchange (swap) the B and A registers; then clear register B. MODES=SRV, FORMAT=GEN, OPCODE=140204, C=unchanged, L=unchanged, CC=unchanged. ## PROGRAM CONTROL AND JUMP—PCTLJ ## ARGT Argument transfer The Argument Transfer operation must be the first executable instruction of any procedure which takes arguments. It serves as a holding point for the program counter while argument transfer is taking place into the new frame. The program counter is advanced past it when argument transfer is complete. Procedures which specify zero arguments in their entry control blocks must not begin with an ARGT. The list of argument transfer templates following the caller's PCL instruction is evaluated to generate a list of actual argument pointers in the new frame. The format of each argument transfer template is shown in Section 9. Each argument pointer may require one or more templates for its generation. The last template for each argument has its S (store) bit set. The last template for the last argument in the list has its L (last) bit set to terminate the argument transfer. Each template specifies the calculation of an address by specifying a base register, a word and bit displacement from that register, and an optional indirection. If further offsets or indirections are required to generate the final argument address, the template will not have its store bit set, and the address calculated so far will be placed in the temporary base (XB) register (ring, segment, word numbers) and X-register (bit number) for access by the next template. Only one level of indirection can be specified by each AP. Each time a template with its store bit set is encountered, the calculated address is stored in the next argument pointer position in the new stack frame. The first argument pointer position is specified in the procedure's ECB. If the address has a zero bit offset, the address is stored in the two-word indirect format (with the E-bit clear) and the third word is not modified. Otherwise it is stored in the three-word format (E-bit set). In either case, three words are allocated to each pointer in the argument list. If the caller's template list generates fewer arguments than are expected by the callee (as specified in the entry control block), argument pointers containing the pointer-fault bit set and all other bits reset (pointer-fault code 100000, "omitted argument") are stored for the missing arguments. The second and third words are not modified. On the other hand, if the caller's list generates more arguments than are specified by the callee, the surplus arguments are ignored. If the called procedure attempts to reference an omitted argument, other than to simply pass it on in another call, it will experience a pointer fault. If it passes on an omitted argument in another call, the argument will appear omitted to the newly called procedure. If a call intends to omit all expected arguments, it may be followed by an argument transfer template with its last bit set but with its store bit cleared. $\label{eq:modes} \textbf{MODES} = V, \ \textbf{FORMAT} = GEN, \ \textbf{OPCODE} = 000605, \ \textbf{C} = unspecified, \ \textbf{L} = unspecified, \ \textbf{CC} = unspecified.$ ## ► CEA Compute effective address Interpret the contents of the A register as a 16-bit indirect address word in the current addressing mode, calculate the effective address, and place the final effective address back in the A register. MODES=SR, FORMAT=GEN, OPCODE=000111, C=unchanged, L=unchanged, CC=unchanged. ## ► CREP addr Call recursive entry procedure $$(P)$$ + $\rightarrow$ $[(S)$ +1] EA $\rightarrow$ $(P)$ Increment the program counter, P, and load P+1 into the location following the one specified by the current R-mode stack pointer. Load addr into the program counter and continue execution from that location. The CREP instruction performs subroutine linkage for recursive or reentrant procedures. CREP stores the return address in the second word of a stack frame created by the ENTR instruction, rather than in the destination address as in a JST. MODES=R, FORMAT=MR, OPCODE=10 02, C=unchanged, L=unchanged, CC=unchanged. ## EAA addr Effective address to A register $$EA \rightarrow A$$ Calculate the effective address and load it into register A. The contents of addr are unaffected and the original contents of register A are overwritten and lost. MODES=R, FORMAT=MR, OPCODE=01 01, C=unchanged, L=unchanged, CC=unchanged. ## EAL addr Effective address to L Calculate the effective address and put it into the L register. MODES=V, FORMAT=MR, OPCODE=01 01, C=unchanged, L=unchanged, CC=unchanged. #### EALB addr Effective address to LB EA→LB Calculate the effective address and put it into the link base, LB. MODES=V, FORMAT=MR, OPCODE=13 02, C=unchanged, L= unchanged, CC=unchanged. #### EAXB addr Effective address to XB EA→XB Calculate the effective address and put it into the temporary base, XB. MODES=V, FORMAT =MR, OPCODE=12 02, C=unchanged, L=unchanged, CC=unchanged. ## ENTR n Enter R-mode recursive procedure stack $$(S)1 \rightarrow [(S)1-n]$$ $(S)1-n \rightarrow (S)2$ Alter the R-Mode stack pointer by subtracting the value of N and store the previous value of S in the new location. The ENTR instruction allocates a block of memory as a stack frame containing N locations: The frame is created by subtracting N from the stack pointer contents, (S)1, to form (S)2, and then storing (S)1 at that address. Thus, the first word of the frame points to the previous frame. N may be negative or positive. **MODES**=R, **FORMAT**=MR, **OPCODE**=01 03, **C**= unchanged, **L**=unchanged, **CC**=unchanged. ## JDX addr Jump and decrement X X=X-1; if X=0, then $EA\rightarrow PC$ ; else PC=PC+1 Decrement the contents of the X register by one; then, if the contents of X are not equal to zero, load addr into the program counter and continue sequential operation from that location. Otherwise, execute the next sequential instruction. MODES=R, FORMAT=MR, OPCODE=15 02, C=unchanged, L=unchanged, CC=unchanged. ## JEQ addr Jump if equal to zero If A=0, then $EA\rightarrow PC$ If the contents of the A register are equal to zero, then load addr into the program counter and continue sequential operation from that location. MODES=R, FORMAT=MR, OPCODE =02 03, C=unchanged, L=unchanged, CC=unchanged. ## JGE addr Jump if greater than or equal to zero If A≥0, then EA→PC If the contents of the A register are greater than or equal to zero, then load addr into the program counter and continue sequential operation from that location. MODES=R, FOR-MAT=MR, OPCODE=07 03, C=unchanged, L=unchanged, CC=unchanged. ## JGT addr Jump if greater than zero If A>0, then $EA\rightarrow PC$ If the contents of the A register are greater than zero, then load addr into the program counter and continue sequential operation from that location. MODES=R, FORMAT=MR, OPCODE=05 03, C=unchanged, L=unchanged, CC=unchanged. ## JIX addr Jump and increment X X=X+1; if X=0, then $EA\rightarrow PC$ ; else PC=PC+1 Increment the contents of the X register by one; then, if the contents of X are not equal to zero, load addr into the program counter and continue sequential operation from that location. Otherwise, execute the next sequential instruction. MODES=R, FORMAT=MR, OPCODE=15 03, C=unchanged, L=unchanged, CC=unchanged. ## JLE addr Jump if less than or equal to zero If A≤0, then EA→PC If the contents of the A register are less than or equal to zero, then load addr into the program counter and continue sequential operation from that location. MODES=R, FOR-MAT=MR, OPCODE=04 03, C=unchanged, L=unchanged, CC=unchanged. ## JLT addr Jump if less than zero If A<0, then EA→PC If the contents of the A register are less than zero, then load addr into the program counter and continue sequential operation from that location. MODES=R, FORMAT=MR, OPCODE =06 03, C=unchanged, L=unchanged, CC=unchanged. ## JMP addr Jump EA→PC Transfer control to location addr by loading addr into the program counter and continue sequential operation from that location. MODES=SRV, FORMAT=MR, OPCODE=01, C= unchanged, L=unchanged, CC=unchanged. ## ▶ JNE addr Jump if not equal to zero If A≠0, then EA→PC If the contents of the A register are not equal to zero, then load addr into the program counter and continue sequential operation from that location. MODES=R, FORMAT=MR, OPCODE=03 30, C=unchanged, L=unchanged, CC=unchanged. ## JST addr Jump and store $PC\rightarrow [EA]16;EA+1\rightarrow PC$ Call a subroutine by storing the contents of the program counter (which points to the next location after the JST instruction) in location addr. Continue execution at location addr+1. In non-restricted mode, interrupts are inhibited for one instruction cycle following a JST. The return address is truncated according to the addressing mode before it is stored, and higher-order bits of the memory location are not altered. It is thus possible to preset the I or X bits of such locations: | Mode | <b>Preset Allowed</b> | |----------|-----------------------| | 16S | I, X | | 32S, 32R | I | | 64, 64V | - | #### Note Cannot be used in shared code. MODES=SRV, FORMAT=MR, OPCODE=10, C=unchanged, L=unchanged, CC=unchanged. #### JSX addr Jump and store return in X $(PC)W\rightarrow X;EA\rightarrow PC$ Increment the program counter by one and load into the X register. Load addr into the program counter and continue sequential operation from that location. **MODES=RV**, **FORMAT=MR**, **OPCODE=**35 03, **C=unchanged**, **L=unchanged**, **CC=unchanged**. #### JSXB addr Jump and set XB PC→XB:EA→PB Save the 32-bit contents of the program counter in XB, and transfer control to location addr. JSXB may be used to make both intersegment and intrasegment subroutine calls. **MODES**= V, **FORMAT**=MR, **OPCODE**=14 02, **C**=unchanged, **L**=unchanged, **CC**=unchanged. ## JSY addr Jump and set Y $(PC)W\rightarrow Y;EA\rightarrow PB$ Save the word number of the program counter in the Y register and transfer control to location addr. Only the word number portion of the return address is saved, JSY may (usually) only be used to call subroutines that reside in the same procedure segment. MODES=V, FORMAT=MR, OPCODE=14, C=unchanged, L=unchanged, CC=unchanged. #### PCL addr Procedure call Call procedure whose ECB is at addr. #### Step 1. Calculation of target ring number - 1. If the caller has Read access to the segment (segment number of addr) containing the ECB, new ring=current ring. - 2. If the caller has gate access to the segment containing the ECB, new ring=ring field of ECB(PB). The ECB must start on a modulo-16 boundary in this case. If neither 1. nor 2. holds, an access violation results. #### Step 2. Stack frame allocation - 1. If ECB(stack root)=0, then stack root=ECB(stack root), else stack root = current stack segment. - 2. Fetch the free pointer at location 0 of segment (stack root). If there is sufficient room remaining (size needed given by ECB(SFSIZE), allocate frame here and update free pointer in segment stack root. - 3. If no room in this segment, fetch the extension pointer at location 2 of the segment pointed to by free pointer. If 0, generate stack overflow fault. Else, use extension pointer as a new free pointer and go to step 2. #### Step 3. New frame header setup - 1. The flag word (word 0) is set to 0. - 2. The caller's PB, SB, LB and keys are saved (X,Y and XB are lost) in the frame header. The ring field of PB properly reflects the ring of execution of the caller. The saved PB at this moment points to the word following the PCL instruction. It will be updated when argument transfer (if any) is complete to point beyond the argument templates. Word '11 of the stack frame is set to the word number of this initial value of saved PB (i.e., points to PCL+2). #### Step 4. Callee state load 1. The callee's PB, LB, and keys are loaded from the entry control block, except that the ring field of PB has no effect if the ECB is not a gate. The SB register is set to point at the new stack frame. #### Step 5. Argument transfer 1. If ECB(NARGS) is 0, this step is skipped. Otherwise, the one or more AP's (argument templates) following the PCL instruction are processed to load argument pointers into the callee's stack frame. At least one AP must follow PCL if the callee expects arguments; no AP may follow if the callee expects no arguments. The saved PB in callee's stack frame is updated to point beyond the AP's when argument transfer is done. See the ARGT instruction for a description of argument transfer. MODES=V, FORMAT=MR, OPCODE=10 02, C=unspecified, L=unspecified, CC=unspecified #### PRTN Procedure return Deallocates the current stack frame and returns to the environment of the procedure that called it. The stack frame is deallocated by storing the current stack base register into the free pointer. The caller's state is restored by loading his program counter, stack base register, linkage base register, and keys from the frame being left. The ring number in the program counter is weakened with the current ring number. The current stack frame consists of the frame created upon entry to the current procedure plus all extensions created during the execution of the current procedure. MODES=V, FORMAT=GEN, OPCODE=000611, C=loaded by instruction, L=loaded by instruction. ## RTN Return from R-mode recursive procedure $$[(S)\!+\!1]\!\to\! P[(S)]\!\to\! S$$ Fetch the return address from word 2 of the previous stack frame and load the result in the program counter; then transfer word 1 (the pointer to the preceding stack frame) to the S register. If the return address is 0, (S) is unchanged and a PSU (Procedure Stack Underflow) fault is taken (interrupt through location '75 in physical memory is taken on the Prime 300). **MODES** =SR, **FORMAT**=GEN, **OPCODE**=000105, **C**=unchanged, **L**=unchanged, **CC**=unchanged. #### STEX Stack extend Obtains additional space in the procedure stack for automatic variables. Such space is automatically deallocated and reclaimed for other uses when the procedure returns, just like the original frame created when the procedure was entered. The L register specifies the desired contiguous size of the extension in words. The size is rounded up to an even number of words. The address of the extension is returned as a segment number/word number pointer in the L register. It is possible that the extension may not be contiguous with the initial frame (there may have been insufficient room left in the same segment). Any number of extensions may be made. This instruction can cause a stack overflow fault. MODES=V, FORMAT=GEN, OPCODE=001315, C=unspecified, L=unspecified, CC=unspecified. #### XEC addr Execute Execute the instruction at location addr, but do not transfer control to that location. Not all instructions can be executed by the instruction. No multi-word instructions can be executed properly. All one-word instructions can be executed properly except JMP, JST, and address-mode changing generics. Instructions which skip do so relative to the XEC instruction. On any fault or interrupt, the saved program counter is relative to the XEC instruction. MODES=RV, FORMAT=MR, OPCODE =01 02, C=unchanged, L=unchanged, CC=unchanged. ## PROCESS EXCHANGE (RESTRICTED)—PRCEX There are seven process exchange instructions: | Mnemonic | Opcode | C | L | CC | |----------|--------|-------------|-------------|-------------| | INBC | 001217 | unspecified | unspecified | unspecified | | INBN | 001215 | unspecified | unspecified | unspecified | | INEC | 001216 | unspecified | unspecified | unspecified | | INEN | 001214 | unspecified | unspecified | unspecified | | NFYB | 001211 | unspecified | unspecified | unspecified | | NFYE | 001210 | unspecified | unspecified | unspecified | | WAIT | 000315 | unchanged | unchanged | unchanged | See the System Architecture Manual for a complete discussion of the process exchange mechanism. All process exchange instructions are restricted. ## QUEUE MANAGEMENT INSTRUCTIONS—QUEUE The instructions provided for queue manipulation are of the generic-AP class, in which a following AP-pointer provides the address to the queue control block. Section 9 contains the queue control block description. Data is to or from register A and the results of the operation are given in the condition code bits for later testing. addr refers to a control block in virtual space. The virtual queue control block differs from the physical in that a segment number is provided instead of a physical address. Ring zero privilege is required to manipulate physical queues; any non-ring zero attempt to access physical queues will result in a restrict mode violation fault. Also the ring number determines the privilege of access into both the control block and the data block. ## ABQ addr Add to bottom of queue Add the contents of the A-register to the bottom of the queue defined by the QCB at addr. The condition codes are set EQ if the queue is full, e.g., the word could not be added. MODES=V, FORMAT=AP, OPCODE=141716, C=unchanged, L=unchanged, CC=result. ## ATQ addr Add to top of queue Add the contents of the A-register to the top of the queue defined by the QCB (Queue Control Block) at addr. The condition codes are set EQ if the queue is full, e.g., the word could not be added. MODES=V, FORMAT=AP, OPCODE=141717, C=unchanged, L=unchanged, CC=result. ## RBQ addr Remove from bottom of queue Remove a single word from the bottom of the queue defined by the QCB at addr, and place it in the A-register. If the queue is empty, set A=0 and condition codes EQ. **MODES**=V, **FORMAT**=AP, **OPCODE**=141715, **C**=unchanged, **L**=unchanged, **CC**=result. ## RTQ addr Remove from top of queue Remove a single word from the top of the queue defined by the QCB at addr, and place it in the A-register. If the queue is empty, set A=0 and condition codes EQ. MODES=V, FORMAT=AP, OPCODE=141714, C=unchanged, L=unchanged, CC=result. ## TSTQ addr Test queue Set the A-register to the number of items in the queue defined by the QCB at addr. If the queue is empty, set condition codes EQ. MODES=V, FORMAT=AP, OPCODE=141757, C= unchanged, L=unchanged, CC=result. #### SHIFT GROUP—SHIFT Shifting is the movement of the contents of a register bit-to-bit. The instructions in this group shift or rotate right or left the contents of A or the contents of A and B treated as a single register with A on the left. Although these instructions are similar in format and operation, functionally some are logical and others arithmetic. A shift is logical or arithmetic simply in terms of the way the data word is interpreted: a logical shift treats it as a string of bits whereas an arithmetic shift treats it as a signed number. Rotation is a cyclic logical shift such that information rotated out at one end is put back in at the other. The last bit rotated in at the right or left is also saved in C. In a logical right or left shift, the contents of the register or registers are moved bit-to-bit with 0's brought in at the end being vacated. Information shifted out at the other end is lost. The last bit shifted out goes to C. A right arithmetic shift fills the vacated left positions with the sign bit. The C-bit reflects the last bit shifted out on the right. A left arithmetic shift includes the sign, but interprets a sign change as overflow. It fills the vacated right positions with 0's and sets the C-bit on overflow. Hence, arithmetic shifting is equivalent to multiplying or dividing the number by a power of 2, provided no information is lost. These operations also use the C-bit to detect the loss of any bit of significance in a left arithmetic shift, and in all other cases to save the last bit shifted out. In a shift instruction word, bits 3–6 are all 0's and the group is indicated by 01 in bits 1 and 2. Bits 7–10 indicate the particular type of shift, and bits 11–16 specify the twos complement of the number of places to be shifted. Mnemonics are available for the individual types, so the opcode may be regarded as the left four digits of the instruction word, with the word completed by adding the right two digits for the number of places. Note that the mnemonics are constructed using "logical" to mean a logical shift and "shift" to mean specifically an arithmetic shift. ## ALL n A left logical $$\mathsf{C} \leftarrow \mathsf{A}_1 \mathbf{--} \mathsf{A}_{16} \leftarrow \mathsf{0}$$ Shift the contents of register A left n places, bringing zeros into bit 16; data shifted out of bit 1 are lost, except that the last bit shifted out is saved in C. MODES=SRV, FORMAT=SHIFT, OPCODE=0414xx, C=shift extension, L=unspecified, CC=unchanged. #### ALR n A left rotate $$A_1-A_{16} \Leftrightarrow C$$ Shift the contents of register A left n places, rotating bit 1 into bit 16. The last bit rotated back in at the right is also saved in C. MODES=SRV, FORMAT=SHIFT, OPCODE=0416xx, C=shift extension, L=unspecified, CC=unchanged. #### ALS n A left shift $$A_1 \leftarrow A_2 - A_{16} \leftarrow 0$$ Shift the contents of register A left arithmetically n places, bringing zeros into bit 16. Data shifted out of bit 1 are lost. The C-bit is initially cleared. If the sign (bit 1) changes state, set C. A sign change indicates that a bit of significance (a one in a positive number, a zero in a negative) has been shifted out of the magnitude part. MODES=SRV, FORMAT=SHIFT, OPCODE=0415xx, C=overflow, L=unspecified, CC=unchanged. ## ARL n A right logical $$0 \to A_1 - A_{16} \to C$$ Shift the contents of register A right n places, bringing zeros into bit 1; data shifted out of bit 16 are lost, except that the last bit shifted out is saved in C. MODES=SRV, FORMAT=SHIFT, **OPCODE**=0404xx, **C**=shift extension, **L**=unspecified, **CC**=unchanged. ## ARR n A right rotate $$C \Leftrightarrow A_1 - A_{16}$$ Shift the contents of register A right n places, rotating bit 16 into bit 1. The last bit rotated back in at the left is also saved in C. MODES=SRV, FORMAT=SHIFT, OPCODE=0406xx, C =shift extension, L=unspecified, CC=unchanged. ## ARS n A right shift $$A_1 \rightarrow A_2 - A_{16} \rightarrow C$$ Shift the contents of register A right arithmetically n places, leaving the sign (bit 1) unaffected, but shifting it into the magnitude part, zeros in a positive number, ones in a negative. Data shifted out of bit 16 are lost, except that the last bit shifted out is saved in C. MODES=SRV, FORMAT=SHIFT, OPCODE=0405xx, C=shift extension, L=unspecified, CC= unchanged. ## LLL n Long left logical $$\texttt{C} {\leftarrow} \texttt{A}_1 {\leftarrow} \texttt{A}_{16} \leftarrow \texttt{B}_1 {\leftarrow} \texttt{B}_{16} \leftarrow \texttt{0}$$ Shift the contents of registers A and B left n places, bringing zeros into bit 16 of register B. Bit 1 of register B is shifted into bit 16 of register A; data shifted out of bit 1 of register A are lost, except that the last bit shifted out is saved in C. MODES=SRV, FORMAT=SHIFT, **OPCODE**=0410xx, **C**=shift extension, **L**=unspecified, **CC**=unchanged. Shift the contents of registers A and B left n places, rotating bit 1 of register A into bit 16 of register B. Bit 1 of register B shifts into bit 16 of register A. The last bit rotated from register A back to B is also saved in C. MODES=SRV, FORMAT=SHIFT, OPCODE=0412xx, C=shift extension, L=unspecified, CC=unchanged. ## LLS n Long left shift $$A_1 \leftarrow A_2 - A_{16} B_1 B_2 - B_{16} \leftarrow 0$$ Shift the contents of the 31-bit integer in register A|B left arithmetically n places, bringing zeros into bit 16 of register B, bypassing bit 1 of register B; Bit 2 of register B is shifted into bit 16 of register A. Data shifted out of bit 1 of register A are lost. If the sign (bit 1 of register A) changes state, set C; otherwise, clear C. MODES=SR, FORMAT=SHIFT, OPCODE= 0411xx, C=overflow, L=unspecified, CC=unchanged. ## LLS n Long left shift $$C \leftarrow L_1 \leftarrow L_2 \leftarrow L_{32} \leftarrow 0$$ Shift the contents of the 32-bit integer in the L register left arithmetically n places, bringing zeros into bit 32. Data shifted out of bit 1 are lost. If the sign (bit 1) changes state, set C; otherwise clear C. MODES=V, FORMAT=SHIFT, OPCODE=0411xx, C=overflow, L=unspecified, CC=unchanged. ## LRL n Long right logical $$0 \rightarrow A_1 - A_{16} \rightarrow B_1 - B_{16} \rightarrow C$$ Shift the contents of register A and B right n places, bringing zeros into bit 1 of register A. Bit 16 of register A is shifted into bit 1 of register B. Data shifted out of bit 16 of register B are lost, except that the last bit shifted out is saved in C. MODES=SRV, FORMAT=SHIFT. OPCODE=0400xx, C=shift extension, L=unspecified, CC=unchanged. ## LRR n Long right rotate $$C \Leftrightarrow A_1 - A_{16} \rightarrow B_1 - B_{16}$$ Shift the contents of register A and B right n places, rotating bit 16 of register B into bit 1 of register A. Bit 16 of register A is shifted into bit 1 of register B. The last bit rotated from register B back to register A is also saved in C. MODES=SRV, FORMAT=SHIFT, OPCODE =0402xx, C=shift extension, L=unspecified. CC=unchanged. ## LRS n Long right shift $$A_1 \rightarrow A_2 - A_{16} B_1 B_2 - B_{16} \rightarrow C$$ Shift the contents of the 31-bit integer in register A|B right arithmetically n places, leaving bit 1 of register A unaffected, bypassing bit 1 of register B, and shifting the sign (bit 1 of register A) into the magnitude part (zeros in a positive number, ones in a negative). Bit 16 of register A is shifted into bit 2 of register B; data shifted out of B bit 16 are lost, except that the last bit shifted out is saved in C. MODES=SR, FORMAT=SHIFT, OPCODE=0401xx, C=shift extension, L=unspecified, CC=unchanged. #### LRS n Long right shift $$L_1 \rightarrow L_2 \rightarrow L_{32} \rightarrow C$$ Shift the contents of the 32-bit integer in the L register right arithmetically n places, leaving bit 1 unaffected. Data shifted out of bit 32 are lost, except that the last bit shifted out is saved in C. MODES=V, FORMAT=SHIFT, OPCODE=0401xx, C=shift extension, L=unspecified, **CC**=unchanged. #### SKIP CONDITIONAL—SKIP ## DRX Decrement and replace X $$X-1\rightarrow X$$ ; if $X=0$ then $PC+1\rightarrow PC$ Subtract 1 from the contents of the X register and place the result back in that register. Skip the next word in sequence if the result is zero. MODES=SRV, FORMAT=GEN, OPCODE= 140210, C=unchanged, L=unchanged, CC=unchanged. ## IRS addr Increment memory, replace, and skip $$[EA]16+1\rightarrow [EA]16$$ ; if $[EA]16=0$ then $PC+1\rightarrow PC$ Add 1 to the contents of location addr and place the result back in addr. Skip the next word in sequence if the result is zero. MODES=SRV, FORMAT=MR, OPCODE=12, C=unchanged, L=unchanged, CC=unchanged. ## IRX Increment and replace X $$X+1\rightarrow X$$ : if $X=0$ then $PC+1\rightarrow PC$ Add 1 to the contents of the X register and place the result back in that register. Skip the next word in sequence if the result is zero. MODES=SRV, FORMAT=GEN, OPCODE=140114, C =unchanged, L=unchanged, CC=unchanged. ## SAR n Skip on A-bit reset If $$A(n)=0$$ then $PC+1\rightarrow PC$ If bit n in the A register is 0, skip the next word in sequence. #### Note The assembler will convert n to octal equivalent of the bit number minus one. changed. ## SAS n Skip on A-bit Set If $$A(n)=1$$ then $PC+1\rightarrow PC$ If bit n in register A is 1, skip the next instruction in sequence. #### Note The assembler will convert n to the octal equivalent of the bit number minus one. MODES=SRV, FORMAT=GEN, OPCODE=10126x, C=unchanged, L=unchanged, CC=unchanged. #### SGT Skip if A greater than zero If A>0 then PC+1→PC If the contents of register A is greater than zero, skip the next word in sequence. MODES= SRV, FORMAT=GEN, OPCODE=100220, C=unchanged, L=unchanged, CC=unchanged. #### SKP n Skip group Skip conditions are selected by individual bits or combinations of them. - Bits 1-6 are always 100000. - Bit 7=1 means if true, skip the next instruction. - Bit 7=0 means if false, skip the next instruction. - Bit 9=0 means test a combination of bits. The various conditions, the bits that select them and the mnemonics and opcodes for them are given in Table 11-5. **MODES**=SRV, **FORMAT**=GEN, **OPCODE**=100000, **C**=unchanged, **L** =unchanged, **CC**=unchanged. ## SLE Skip if A less than or equal to zero If A≤0 then PC+1→PC If the number contained in A is less than or equal to zero, skip the next word in sequence. **MODES**=SRV, **FORMAT**=GEN, **OPCODE**=101220, **C**=unchanged, **L**=unchanged, **CC**=unchanged. #### SNR n Skip on sense switch reset If sense switch n=0 then $PC+1\rightarrow PC$ If sense switch n is off (not up), skip the next word in sequence. MODES=SRV, FORMAT=GEN, OPCODE=10024x, C=unchanged, L=unchanged, CC=unchanged. Restricted instruction. ## SNS n Skip on sense switch set If sense switch n=1 then $PC+1\rightarrow PC$ If sense switch n is on (up), skip the next word in sequence. MODES=SRV, FORMAT=GEN. OPCODE=10124x, C=unchanged, L=unchanged, CC=unchanged. Restricted instruction. | | | Selector | | | | |----------|-----|----------|-------|---------------------------|---------------| | Mnemonic | | Bits | Bit 7 | Skip on Condition | Op Code | | | NOP | | 1 | None (no-op) | '101000 | | | SKP | | 0 | Skip unconditionally | '100000 | | | SMI | 8 | 1 | A Minus $(A(1) = 1)$ | 101400 | | | SPL | 8 | 0 | A Plus $(A(1) = 0)$ | 100400 | | | SLN | 10 | 1 | LSB Nonzero $(A(16) = 1)$ | 101100 | | | SLZ | 10 | 0.5 | LSB Zero $(A(16) = 0)$ | 100100 | | | SNZ | 11 | 1 | A Nonzero | '101040 | | | SZE | 11 | 0 | A Zero | 100040 | | R | SS1 | 12 | 1 | Sense Switch 1 Set | 101020 | | R | SR1 | 12 | 0 | Sense Switch 1 Reset | 100020 | | R | SS2 | 13 | 1 | Sense Switch 2 Set | 101010 | | R | SR2 | 13 | 0 | Sense Switch 2 Reset | 100010 | | R | SS3 | 14 | 1 | Sense Switch 3 Set | 101004 | | R | SR3 | 14 | 0 | Sense Switch 3 Reset | 100004 | | R | SS4 | 15 | 1 | Sense Switch 4 Set | 101002 | | R | SR4 | 15 | 0 | Sense Switch 4 Reset | 100002 | | R | SSS | 12–15 | 1 | All Sense Switches 1-4 Se | et<br>'101036 | | R | SSR | 12-15 | 0 | Any of Sense Switches 1-4 | | | | | | | | 100036 | | | SSC | 16 | 1 | Set C | `101001 | | | SRC | 16 | 0 | Clear C | 100001 | Skip conditions can be combined using SKP and giving the bit 7–16 configuration for the combination in the address field. All conditions combined must agree on bit 7. If bit 7 is set then the skip will take place if all conditions are true. If bit 7 is clear then the skip will take place if any of the conditions is true. 1 March, 1979 11–55 FDR 3059 # Instruction definitions-I #### ADDRESSING MODE—ADMOD Defined in Section 11. | E16S | Enter 16S Mode | |------|----------------| | E32R | Enter 32R Mode | | E32S | Enter 32S Mode | | E64R | Enter 64R Mode | | E64V | Enter 64V Mode | | E32I | Enter 32I Mode | #### **BRANCH—BRAN** The branch instructions are two word register generics which test the contents of a register or the result of a previous ARITHMETIC or COMPARE operation as indicated by the condition codes (CC), the C-bit, and the L-Bit. The bit layout is: Condition code branches test six conditions based on the LT bit, the EQ bit, and the opcode. | Condition | Meaning | |-----------|---------------------------------------------| | < | Branch if LT bit set and EQ bit cleared | | € | Branch if LT bit set or EQ bit set | | = | Branch if EQ bit set | | <b>≠</b> | Branch if EQ bit cleared | | ≽ | Branch if LT bit cleared or EQ bit set | | > | Branch if LT bit cleared and EQ bit cleared | #### Test Relation to 0 and branch if true These instructions have the following format: $$\left\{ \begin{array}{l} Register \ (R) \\ Half-Register \ (H) \\ Floating-Register \ (F) \end{array} \right\} \qquad \left\{ \begin{array}{l} LT \\ LE \\ EQ \\ NE \\ GE \\ GT \end{array} \right\}$$ For example: BRLT R, addr means Branch to addr if Register Less Than zero. FORMAT= IBRN, OPCODES=See chart below, C=unchanged, L=unchanged, CC=result. | Mnemonic | Function | Opcode | |--------------|--------------------------------------------|--------| | BRLT R,addr | If $R<0$ , then $addr\rightarrow PC$ | 104 | | BRLE R,addr | If R≤0, then addr→PC | 100 | | BREQ R,addr | If R=0, then addr→PC | 102 | | BRNE R,addr | If R≠0, then addr→PC | 103 | | BRGE R,addr | If R≽0, then addr→PC | 105 | | BRGT R,addr | If R>0, then addr→PC | 101 | | BHLT RH,addr | If RH<0, then addr→PC | 104 | | BHLE RH,addr | If RH≤0, then addr→PC | 110 | | BHEQ RH,addr | If RH=0, then addr→PC | 112 | | BHNE RH,addr | If RH≠0, then addr→PC | 113 | | BHGE RH,addr | If RH≥0, then addr→PC | 105 | | BHGT RH,addr | If RH>0, then addr→PC | 111 | | BFLT F,addr | If $F<0$ , then $addr\rightarrow PC$ | 124 | | BFLE F,addr | If $F \leq 0$ , then $addr \rightarrow PC$ | 120 | | BFEQ F,addr | If F=0, then addr→PC | 122 | | BFNE F,addr | If $F\neq 0$ , then addr $\rightarrow PC$ | 123 | | BFGE F,addr | If F≥0, then addr→PC | 125 | | BFGT F,addr | If F>0, then addr→PC | 121 | #### Test register bit and branch **BRBR R,BITNO,addr** Branch if register bit reset (equals zero): If R(BITNO)=0, then addr →PC. **FORMAT**=IBRN, **OPCODE**=040-077, **C**=unchanged, **L**=unchanged, **CC**=unchanged. **BRBS R,BITNO,addr** Branch if register bit set (equals one): If R(BITNO)=1, then addr→PC. **OPCODE**=000-037, **C**=unchanged, **L**=unchanged, **CC**=unchanged. #### Branch on incremented or decremented register These instructions have the following format: $$\left\{ \begin{array}{l} Increment \\ Decrement \end{array} \right\} \ \, \left\{ \begin{array}{l} Register \\ Half \ \, Register \end{array} \right\} \ \, by \left\{ \begin{array}{l} 1 \\ 2 \\ 4 \end{array} \right\} \ \, then \ \, branch \ \, if \ \, result \neq 0$$ For example: BRI1 R,addr means Increment the contents of the Register by 1 and then Branch to addr if the result is not equal to zero. **FORMAT**=IBRN, **OPCODES**-See chart below, **C**=unchanged, **L**=unchanged, **CC**=unchanged. | Mnemonic | Function | Opcode | |--------------|----------------------------------------------------------------|--------| | BRI1 R,addr | $R+1\rightarrow R$ ; if $R\neq 0$ , then $addr\rightarrow PC$ | 130 | | BRI2 R,addr | $R+2\rightarrow R$ ; if $R\neq 0$ , then addr $\rightarrow PC$ | 131 | | BRI4 R,addr | $R+4\rightarrow R$ ; if $R\neq 0$ , then addr $\rightarrow PC$ | 132 | | BHI1 RH,addr | RH+1→RH; if RH≠0, then addr→PC | 140 | | BHI2 RH,addr | RH+2→RH; if RH≠0, then addr→PC | 141 | | BHI4 RH,addr | RH+4→RH; if RH≠0, then addr→PC | 142 | | BRD1 R,addr | $R-1\rightarrow R$ ; if $R\neq 0$ , then addr $\rightarrow PC$ | 134 | | BRD2 R,addr | R-2→R; if R≠0, then addr→PC | 135 | | BRD4 R,addr | R-4→R; if R≠0, then addr→PC | 136 | | BHD1 RH,addr | RH-1→RH; if RH≠0, then addr→PC | 144 | | BHD2 RH,addr | RH-2→RH; if RH≠0, then addr→PC | 145 | | BHD4 RH,addr | RH-4→RH; if RH≠0, then addr→PC | 146 | #### CGT R,n Computed GOTO If 1 < R < n, then $|PC+R| \rightarrow PC$ , else $PC+n \rightarrow PC$ Instruction word followed by n further words: word 1 contains integer n and words 2-n contain branch addresses within the current procedure segment. If the contents of register R is less than n and greater than or equal to 1. then control passes to the address in PC+R; otherwise no branch is taken and control passes to PC+n. **FORMAT** =IBRN. **OPCODE**=026. **C**=unspecified, **L**=unspecified, **CC**=unspecified. Defined in Section 11: | BCEQ | Branch on condition code equal | |------|------------------------------------------------| | BCGE | Branch on condition code greater than or equal | | BCGT | Branch on condition code greater than | | BCLE | Branch on condition code less than or equal | | BCLT | Branch on condition code less than | | BCNE | Branch on condition code not equal | | BCR | Branch if C-Bit=0 | | BCS | Branch if C-Bit=1 | | BLR | Branch if L-Bit=0 | | BLS | Branch if L-Bit=1 | | BMEQ | Branch if magnitude equal 0 | | BMGE | Branch if magnitude greater than or equal 0 | | BMGT | Branch if magnitude greater than 0 | | BMLE | Branch if magnitude less than or equal 0 | | BMLT | Branch if magnitude less than 0 | | BMNE | Branch if magnitude not equal 0 | #### CHARACTER OPERATIONS—CHAR These instructions use the field address and length registers (FALR) which have been set up by field operation instructions prior to the use of these instructions. Character string operations perform memory to memory operations on variable length character fields. The FAR is used as a byte pointer and the bit offset (low order 3 bits) is ignored. 1 March, 1979 12–3 FDR 3059 **Data type**: Characters are 8-bit bytes. The format is unspecified and may be determined by programmer, e.g., ASCII, EBCDIC, etc. The translate instruction (ZTRN), for example, uses a table set up by the programmer to translate one character code into another. #### LDC FALR,R Load Character If the field length register FLR is nonzero, load the single character pointed to by field address register FAR into register R, bits 9–16. Register R bits 1–8 are cleared. The low order 3 bits of the bit offset in the field address register are ignored, implying that the character must be byte aligned. The field address register is advanced 8 bits to the next character, and the field length register is decremented by 1. Set condition code NE (clear EQ). If the field length register is zero, then set the condition code EQ. FORMAT=RGEN, FALRO OPCODE =162, FALR1 OPCODE=172, C=unchanged, L=unchanged, CC=result. #### ► STC FALR, R Store Character Store bits 9–16 of register R into the character pointed to by field address register FAR. The low order 3 bits of the bit offset of the field address register are ignored, implying that the character must be byte aligned. The field address register is advanced 8 bits to the next character, and the field length register is decremented by 1. Set the condition code NE (clear EQ). If the field length register is zero, set the condition code EQ and do not store. FORMAT =RGEN, FALRO OPCODE=166, FALRO OPCODE=176, C=unchanged, L=unchanged, CC=unchanged. #### Summary of instructions defined in section 11 | ZCM | Compare Character Field | |-------------|----------------------------| | ZED | Character Edit | | ZFIL | Fill Character Field | | ZMV | Move Character Field | | <b>ZMVD</b> | Move Equal Length Fields | | ZTRN | Translate Character Fields | #### CLEAR REGISTER AND MEMORY—CLEAR #### CR R Clear Register $0\rightarrow R$ Fill R with zeros. FORMAT=RGEN, OPCODE=056, C=unchanged, L=unchanged, CC=unchanged. #### CRBL R Clear High Byte 1 Left $0 \to RH(1-8)$ Fill bits 1–8 of R with zeros. **FORMAT**=RGEN, **OPCODE**=062, **C**=unchanged, **L**=unchanged, **CC**=unchanged. #### CRBR R Clear High Byte 2 Right $0 \rightarrow RH(9-16)$ Fill bits 9 16 of R with zeros. FORMAT=RGEN, OPCODE=063,, C=unchanged, L=unchanged, CC=unchanged. #### CRHL R Clear Left Halfword $0\rightarrow RH$ Fill bits 1–16 of R with zeros. **FORMAT=**RGEN, **OPCODE=**054, **C=**unchanged, **L=**unchanged, **CC=**unchanged. # CRHR R Clear Right Halfword 0→RL Fill bits 17-32 of R with zeros. FORMAT=RGEN, OPCODE=055, C=unchanged, L=unchanged, CC=unchanged. # ZM addr Zero Memory Fullword $0\rightarrow [EA]32$ Fill contents of addr with zeros. FORMAT=MRNR, OPCODE=43, C=unchanged, L=unchanged, CC=unchanged. # ZMH addr Zero Memory Halfword $0\rightarrow |EA|16$ Fill contents of addr with zeros. FORMAT=MRNR, OPCODE=53, C=unchanged, L=unchanged, CC=unchanged. #### DECIMAL ARITHMETIC—DECI Defined in Section 11: | XAD | Decimal Add | |------|------------------------------| | XBTD | Binary to Decimal Conversion | | XCM | Decimal Compare | | XDTB | Decimal to Binary Conversion | | XDV | Decimal Divide | | XED | Numeric Edit | | XMP | Decimal Multiply | | XMV | Decimal Move | #### FIELD OPERATIONS—FIELD These instructions set up and manipulate the field address and length registers, which are used by both the decimal and character string instructions. The interpretation of the value in the field length registers depends on the data type and instruction using them. # ARFA FAR, R Add Register to Field Address Register R+FAR→FAR Add the contents of R to field address register FAR, putting the result in the field address register. FORMAT=RGEN, FAR0 OPCODE=161, FAR1 OPCODE=171, C=unspecified, L=unspecified, CC=unchanged. # TFLR FLR,R Transfer Field Length to Register FLR→R Move the contents of field length register FLR to R. FORMAT=RGEN, FLR0 OPCODE=163, FLR1 OPCODE=173, C=unchanged, L=unchanged, CC=unchanged. # TRFL FLR,R Transfer Register to Field Length Register #### R→FLR Move the content of R to field length register FLR. FORMAT=RGEN, FLR0 OPCODE=165. FLR1 OPCODE=175, C=unchanged, L=unchanged, CC=unchanged. # Summary of instructions defined in section 11 | EAFA 0 | Load Field Address Register 0 | |--------|----------------------------------------| | EAFA 1 | Load Field Address Register 1 | | LFLI 0 | Load Field Length Register Immediate 0 | | LFLI 1 | Load Field Length Register Immediate 1 | | STFA 0 | Store Field Address Register | | STFA 1 | Store Field Address Register | #### FLOATING POINT ARITHMETIC—FLPT See Section 9 for a description of the processor dependent register formats and the floating point data stuctures. #### Normalization The result of every floating point calculation is normalized. In normal form, the most significant digit of the mantissa follows the binary point. If an operation produced a mantissa that is smaller than normal, the mantissa is shifted left until the most significant bit differs from the sign bit, and the exponent is decreased by one for each shift. Bits vacated at the right are filled by zeros. If the result of an operation overflows the mantissa, it is shifted right one place, the overflow bit is made the most significant bit, and the exponent is increased by 1. #### Floating point exceptions In the basic arithmetic operations, increasing the exponent in the floating point register beyond 32639 is an overflow; decreasing it below -32896 is an underflow. An attempt to store a single-precision number with an exponent greater than 127 or less than –128 in the two-word memory format results in a different type of exception—see Table 11-2. The number in the floating point register is not altered by the FST operation and so can be recovered if necessary. Other detected exceptions are an attempt to divide by zero or to form an integer exceeding $\pm 30$ bits or about $\pm 1$ billion decimal. On the Prime 350 and up, the floating point exception is a fault rather than an interrupt and is controlled by the FLEX bit in the keys—see Section 9—Data Formats. # Single Precision—32 bits #### ► FA FR,addr Floating Add #### FR1|EA|32→FR Add the floating point number at addr to the contents of the floating point number in floating point register FR, and leave the resulting floating point number in the floating point register. Addition of floating point numbers requires that their exponents be the same power of two. This is accomplished by right shifting the smaller number by the difference in the exponents. After alignment, the mantissas are added. FORMAT=MRFR, FR0 OPCODE=14, FR1 OPCODE=16, C=overflow, L=unspecified, CC=unspecified. #### FC FR, addr Floating Compare FR::|EA|32 Compare the contents of floating point register FR with the contents of addr and set the condition codes accordingly. FORMAT=MRFR, FR0 OPCODE=04, FR1 OPCODE=06, C= unchanged, L=unchanged, CC=result. #### FCM FR Floating Complement -FR→FR Two's complement the mantissa of floating point register FR and normalize if necessary. FORMAT=RGEN. FR0 OPCODE=100, FR1 OPCODE=110, C=overflow, L=unspecified, CC=unspecified. #### FD FR,addr Floating Divide FR/|EA|32→FR Divide the contents of floating point register FR by the number in addr and leave the normalized quotient in the floating point register.l FORMAT=MRFR. FR0 OPCODE=30. FR1 OPCODE=32. C=overflow. L=unspecified. CC=unspecified. #### ► FL FR,addr Floating Load |EA|32→FR Load the floating point number contained in addr into floating point register FR. **FORMAT** =MRFR, **FR0 OPCODE**=00, **FR1 OPCODE**=02, **C**=unchanged, **L**=unchanged, **CC**=unchanged. # FLT FR,R Convert Integer to Floating Point Float (R)→FR Convert the integer in R to a normalized floating point number in floating point register FR. **FORMAT**=RGEN, **FR0 OPCODE**=105, **FR1 OPCODE**=115, **C**=overflow, **L**=unspecified, **CC**= unspecified. # FLTH FR,R Convert Halfword Integer to Floating Point FLOAT(RH)→FR Convert the halfword integer in RH to a normalized floating point number in floating point register FR. FORMAT=RGEN, FR0 OPCODE=102, FR1 OPCODE=112, C=overflow, L=unspecified, CC=unspecified. # FM FR,addr Floating Multiply FR\*'|EA|32→FR Multiply the contents of floating point register FR by the contents of addr and place the product in the floating point register with the mantissa normalized. FORMAT=MRFR, FRO OPCODE=24, FR1 OPCODE=26, C=overflow, L=unspecified, CC=unspecified. # FRN FR Floating Round If bit 25 of the mantissa in floating point register FR is 1, add 1 to bit 24 and clear 25. FORMAT=RGEN, OPCODE=107, C=overflow, L=unspecified, CC=unspecified. #### ► FS FR,addr Floating Subtract #### FR-[EA]32→FR Subtract the contents of addr from floating point register FR by aligning exponents, and proceding as in FA except that the contents of addr are subtracted from floating point register. FORMAT=MRFR, FR0 OPCODE=20, FR1 OPCODE=22, C=overflow, L=unspecified, CC=unspecified. # FST FR,addr Floating Store #### $FR \rightarrow [EA]32$ Store the single precision floating point number contained in floating point register FR in addr. Bits 24–31 of the 31 bit mantissa are truncated when written into the 23-bit capacity memory storage. However, the mantissa may be rounded to bit 24 by a FRN instruction which adds 1 to bit 24 if bit 25 is 1. FORMAT=MRFR, FR0 OPCODE=10, FR1 OPCODE=12, C=overflow, L=unspecified, CC=unchanged. # INT FR.R Convert Floating Point to Integer #### $Int(FR) \rightarrow R$ Convert the floating point number in floating point register FR to an integer in R. FORMAT =RGEN, FR0 OPCODE 103, FR1 OPCODE 113, C=overflow, L=unspecified, CC=unspecified. #### ► INTH FR,R Convert Floating Point to Halfword Integer #### $Int(FR)\rightarrow RH$ Convert the floating point number in floating point register FR to a halfword integer in RH. **FORMAT**=RGEN, **FR0 OPCODE**=101, **FR1 OPCODE**=111, **C**=overflow, **L**=unspecified. **CC**= unspecified. #### Double Precision—64 Bits # DBLE FR Convert Single to Double #### FR→FR Convert single precision floating point number in floating point register FR to double precision floating point number in the floating point register. FORMAT=RGEN, FRO OPCODE=106, FR1 OPCODE=116, C=unchanged, L=unchanged, CC=unchanged. # DFA FR,addr Double Floating Add #### $FR+[EA]64\rightarrow FR$ Add the contents of addr to the contents of floating point register FR and put the result in the floating point register. FORMAT=MRFR, FR0 OPCODE=15, FR1 OPCODE=17, C=overflow, L=unspecified, CC=unspecified. # DFC FR,addr Double Floating Compare #### FR::[EA]64 Compare the contents of addr with the contents of floating point register FR and set the condition codes accordingly. FORMAT=MRFR, FR0 OPCODE=05, FR1 OPCODE=07, C= unchanged, L=unchanged, CC=result. # DFCM FR Double Floating Complement -FR→FR Two's complement the double precision mantissa in floating point register FR and normalize if necessary. FORMAT=RGEN, FR0 OPCODE=144, FR1 OPCODE=154, C=overflow, L=unspecified, CC=unspecified. # DFD FR,addr Double Floating Divide FR/|EA|64→FR Divide the double precision floating point number in floating point register FR by the double precision floating point number starting at addr and leave the result in the floating point register. Exponents are subtracted, and after the divisor mantissa is divided into the dividend mantissa, the quotient is normalized. FORMAT=MRFR, FR0 OPCODE=31, FR1 OPCODE=33, C=overflow, L=unspecified, CC=unspecified. # DFL FR,addr Double Floating Load |EA|64→FR Load the double precision number contained in the four memory words at addr into floating point register FR. FORMAT=MRFR, FR0 OPCODE=01, FR1 OPCODE=03, C=unchanged, L=unchanged, CC=unchanged. # DFM FR,addr Double Floating Multiply FR+|EA|64→FR Multiply the double precision floating point number in floating point register FR by the double precision floating point number starting at addr and leave the result in the floating point register. Exponents are added and, after mantissas are multiplied, the product is normalized. FORMAT=MRFR, FR0 OPCODE=25, FR1 OPCODE=27. C=overflow, L=unspecified, CC=unspecified. # DFS FR,addr Double Floating Subtract FR -|EA|64→FR Subtract the contents of addr from the contents of floating point register FR and put the result in the floating point register. FORMAT=MRFR. OPCODE=21. FR0 OPCODE=21. FR1 OPCODE=23. C=overflow, L=unspecified. CC=unspecified. # DFST FR,addr Double Floating Store $FR \rightarrow |EA|64$ Store the contents of floating point register FR into the four memory words at addr. FORMAT=MRFR, FR0 OPCODE=11, FR1 OPCODE=13, C=unchanged, L=unchanged, CC=unchanged. #### INTEGER ARITHMETIC—INT I-mode integer arithmetic instructions operate on 16 and 32 bit integers. See Section 9 for a description of the data formats. # A R,addr Add Fullword $R + |EA|32 \rightarrow R$ Add the 32-bit integer at addr to the 32-bit integer in register R, and put the result into R. FORMAT=MRGR, OPCODE=02, C=overflow, L=carry, CC=result. #### ADLR R Add Link to Register if keys (L)=1 then $R+11\rightarrow R$ If the L bit is set in the keys then add 1 to the contents of register R. FORMAT=RGEN. OPCODE=014, C=overflow, L=carry, CC=result. #### ► AH R.addr Add Halfword RH+|EA|16→RH Add the 16-bit integer at addr to the 16-bit integer in bits 1–16 of register R and put the result into bits 1–16 of R. FORMAT=MRGR, OPCODE=12, C=overflow, L=carry, CC=result. # C R,addr Compare Fullword R::|EA|32; set CC. Arithmetically compare the 32-bit integer in R with the 32-bit integer at addr and set the condition codes to reflect the results. FORMAT=MRGR, OPCODE=61. C=unchanged. L= carry, CC=result. # CH R,addr Compare Halfword RH::|EA|16; set CC. Arithmetically compare bits 1–16 of register R with the 16-bit integer at addr and set the condition codes to reflect the results. FORMAT=MRGR. OPCODE=71. C=unchanged. L=carry, CC=result. # CHS R Change Sign $-R(1)\rightarrow R(1)$ Change bit 1 of register R to its opposite. FORMAT=RGEN, OPCODE=040. C=unchanged, L =unchanged, CC=unchanged. # CSR R Copy Sign $R(1)\rightarrow C$ ; $0\rightarrow R(1)$ Copy the sign bit of register R, (bit 1), into C and zero R(1). **FORMAT**=RGEN. **OPCODE**=041. **C**=R(1), **L**=unchanged, **CC**=unchanged #### D R.addr Divide Fullword $R|R+1/|EA|32\rightarrow R$ ; Remainder $\rightarrow R+1$ Divide the 64-bit integer in registers R and R+1 by the 32-bit integer at addr, and put the result in R and the remainder in R+1. The least significant bit of the dividend is in bit 64. Overflow if the quotient is less than $-(2^{**}31)$ or greater than $2^{**}31$ -1. R must be an even register. FORMAT=MRGR, OPCODE=62, C=overflow/div by 0, L=unspecified. CC=unspecified. #### DH R,addr Divide Halfword R/[EA|16→RH; Remainder→RH Divide the 32-bit integer in register R by the 16-bit integer at addr, and put the quotient into bits 1-16 of R and the remainder into bits 17-32 of R. The least significant bit of the dividend is in bit 32. Overflow if the quotient is less than -(2\*\*15) or greater than 2\*\*15-1. FORMAT =MRGR, OPCODE=72, C=overflow/div by 0, L=unspecified, CC=unspecified. # DH1 R Decrement Half Register by 1 RH-1→RH Subtract one from RH and put the results into RH. FORMAT=RGEN, OPCODE=130, C= overflow, L=carry, CC=result. #### DH<sub>2</sub> R Decrement Half Register by 2 RH-2→RH Subtract two from RH and put the result into RH. FORMAT=RGEN, OPCODE=131, C= overflow, L=carry, CC=result. # DM addr Decrement Memory Fullword $|EA|32-1\rightarrow |EA|32$ Subtract one from the 32-bit integer at addr and put the result into addr. FORMAT=MRNR, OPCODE=60. C=unchanged, L=unchanged, CC=result. #### DMH addr Decrement Memory Halfword $|EA|16-1 \rightarrow |EA|16$ Subtract one from the 16-bit integer at addr and put the result into addr. FORMAT=MRNR, OPCODE=70, C=unchanged, L=unchanged, CC=result. # DR1 R Decrement Register by 1 $R-1\rightarrow R$ Subtract one from the contents of R and put the result into R. FORMAT=RGEN. OPCODE= 124, C=overflow, L=carry, CC=result. # DR2 R Decrement Register by 2 $R-2\rightarrow R$ Subtract two from the contents of R and put the result into R. FORMAT=RGEN. OPCODE= 125, C=overflow, L=carry, CC=result. # IH1 Increment Half Register by 1 RH+1→RH Add one to the contents of RH and put the result into RH. FORMAT=RGEN, OPCODE=126, C=overflow, L=carry, CC=result. # IH2 R Increment Half Register by 2 RH+2→RH Add two to the contents of RH and put the result into RH. FORMAT=RGEN. OPCODE=127. C=overflow, L=carry, CC=result. #### ► IM addr Increment Memory Fullword $[EA]32+1\rightarrow [EA]32$ Add one to the 32-bit integer at addr and put the result into addr. FORMAT=MRNR, OPCODE=40, C=unchanged, L=unchanged, CC=result. #### IMH addr Increment Memory Halfword [EA]16+1→[EA]16 Add one to the 16-bit integer at addr and put the result into addr. FORMAT=MRNR, OPCODE=50, C=unchanged, L=unchanged, CC=result. #### IR1 R Increment Register by 1 $R+1\rightarrow R$ Add one to the contents of register R and put the result in R. FORMAT=RGEN, OPCODE= 122, C=overflow, L=carry, CC=result. #### IR2 R Increment Register by 2 $R+2\rightarrow R$ Add two to the contents of register R and put the result in R. FORMAT=RGEN, OPCODE= 123, C=overflow, L=carry, CC=result. # M R,addr Multiply Fullword $R^*[EA]32\rightarrow R|R+1$ Multiply the 32-bit integer in register R by the 32-bit integer at addr and put the 64-bit result into R and R+1. The least significant bit is in bit position 64. R must be an even register. **FORMAT=MRGR**, **OPCODE=**42, **C=overflow**, **L=unspecified**, **CC=unchanged**. # MH R,addr Multiply Halfword RH\*[EA]16→R Multiply the 16-bit integer in bits 1–16 of register R by the 16-bit integer at addr and put the 32-bit result into R. The least significant bit is in bit position 32. **FORMAT**=MRGR, **OPCODE** =52. **C**=overflow, **L**=unspecified, **CC**=unchanged. #### PID R Position For Integer Divide $R \rightarrow R + 1$ ; $R(1) \rightarrow R(2-32)$ Convert the 32-bit integer in register R to a 64 integer in registers R and R+1 by moving the contents of R to R+1, and extending the sign in bit 1 of R through bits 2-32 of R. FORMAT= RGEN, OPCODE=052, C=unchanged, L=unchanged, CC=unchanged. #### PIDH R Position Half Register For Integer Divide $RH\rightarrow RL; R(1)\rightarrow R(2-16)$ Convert the 16-bit integer in RH to 32-bit integer in R by moving the contents of RH to RL, and extending the sign in bit 1 through bits 2–16 of R. FORMAT=RGEN, OPCODE=053, C= unchanged, L=unchanged, CC=unchanged. #### ▶ PIM R Position After Multiply $R+1\rightarrow R$ Convert the 64-bit integer in registers R and R+1 to a 32-bit integer in R by moving the contents of R+1 to R. Overflow if a loss of precision would result. (i.e., bit 1 of R+1 is not the same as all the bits of R). FORMAT=RGEN, OPCODE=50, C=overflow, L=unspecified, CC =unspecified. # PIMH R Position Half Register After Multiply RL→RH Convert the 32-bit integer in register R to a 16-bit integer in RH by moving the contents of RL to RH. Overflow if a loss of precision would result. **FORMAT**=RGEN, **OPCODE**=51, **C**= overflow, **L**=unspecified, **CC**=unspecified. # S R,addr Subtract Fullword $R-[EA]32\rightarrow R$ Subtract the 32-bit integer at addr from 32-bit integer in register R, and put the result into R. **FORMAT**=MRGR, **OPCODE**=22, **C**=overflow, **L**=carry, **CC**=result. #### SH R,addr Subtract Halfword RH-[EA]16→RH Subtract the 16-bit integer at addr from the 16-bit integer in bits 1–16 of register R and put the result into bits 1–16 of R. FORMAT=MRGR, OPCODE=32, C=overflow, L=carry, CC= results. # SSM R Set Sign Minus $1\rightarrow R(1)$ Set the sign bit of register R, (bit 1), equal to one. **FORMAT=RGEN**, OPCODE=042, **C=unchanged**, **L=unchanged**, **CC=unchanged**. # SSP R Set Sign Plus $0\rightarrow R(1)$ Set the sign bit of register R, (bit 1), equal to zero. FORMAT=RGEN, OPCODE=043, C=unchanged, L=unchanged, CC=unchanged. # TC R Two's Complement Register $-R+1\rightarrow R$ Replace the contents of register R by its two's complement. **FORMAT**=RGEN, **OPCODE**= 046, **C**=overflow, **L**=carry, **CC**=result. # TCH R Two's Complement Half Register -RH+1→RH Replace the contents of RH by its two's complement. **FORMAT=**RGEN, **OPCODE=**047, **C=** overflow, **L=**carry, **CC=**result. #### TM addr Test Memory Fullword [EA]32::0; set CC Test the contents of addr and set condition code accordingly. **FORMAT**=MRNR, **OPCODE**=44, **C**=unchanged, **L**=unchanged, **CC**=result. #### TMH addr Test Memory Halfword [EA]16:0;set CC Test the contents of addr and set condition code accordingly. FORMAT=MRNR, OPCODE=54, C=unchanged, L=unchanged, CC=result. #### INTEGRITY CHECK FOR HARDWARE—INTGY Defined in Section 11. | <b>EMCM</b> | Enter Machine Check Mode | |-------------|---------------------------------------| | LMCM | Leave Machine Check Mode | | MDEI | Memory Diagnostic Enable Interleaved | | MDII | Memory Diagnostic Inhibit Interleaved | | MDIW | Memory Diagnostic Write Interleaved | | MDRS | Memory Diagnostic Read Syndrome Bits | | MDWC | Load Write Control Register | | RMC | Clear Machine Check | | VIRY | Verify | | XVRY | Verify xis | #### INPUT/OUTPUT—I/O #### EIO addr Execute I/O Interpret the low order 16 bits of addr as a Prime 400 PIO instruction. Set EQ on successful INA, OTA, SKS; OCP always sets NE. FORMAT=MRNR, OPCODE=34, C=unchanged. L= unchanged, CC=result. #### Summary of instructions from section 11 | CAI | Clear Active Interrupt | |-------------|-------------------------------| | ENB | Enable Interrupts | | <b>ESIM</b> | Enter Standard Interrupt Mode | | EVIM | Enter Vectored Interrupt Mode | | INH | Inhibit Interrupts | | IRTC | Interrupt Return | | IRTN | Interrupt Return | #### KEY MANIPULATION—KEYS Moves keys to and from registers. See Section 9 for the format of the keys. # INK R Input Keys keys→RH Save contents of keys in RH. FORMAT=RGEN, OPCODE=070, C=unchanged, L=unchanged, CC=unchanged. #### OTK R Output Keys RH→keys Restore keys from RH. **FORMAT**=RGEN, **OPCODE**=071, **C**=loaded by instruction, **CC**=loaded by instruction. Defined in Section 11: **RCB** Reset C-Bit (Clear) **SCB** Set C-Bit #### LOGICAL OPERATIONS—LOGIC #### CMH RH Complement Half Register NOT.RH→RH Ones complement the contents of RH. **FORMAT**=RGEN, **OPCODE**=045, **C**=unchanged, **L**=unchanged, **CC**=unchanged. #### CMR R Complement Register NOT.R→R Ones complement the contents of R. FORMAT=RGEN, OPCODE=044, C=unchanged, L=unchanged, CC=unchanged. #### N R,addr AND Fullword R.AND.|EA|32→R AND the contents of R and addr and put the result into R. FORMAT=MRGR, OPCODE=03, C=unchanged, L=unchanged, CC=unchanged. #### NH R,addr AND Halfword RH.AND.|EA|16→RH AND the contents of RH and addr and put the result into RH. **FORMAT=**MRGR. **OPCODE** =13. **C**=unchanged, **L**=unchanged, **CC**=unchanged. #### O R,addr OR Fullword R.OR.|EA|32→R OR the contents of R and addr and put the result into R. FORMAT=MRGR. OPCODE=23. C =unchanged. L=unchanged. CC=unchanged. #### OH R, addr OR Halfword RH.OR.|EA|16→RH OR the contents of RH and addr and put the result into RH. **FORMAT**=MRGR. **OPCODE**= 33. **C**=unchanged. **L**=unchanged. **CC**=unchanged. #### X R, addr Exclusive OR Fullword R.XOR.|EA|32→R Exclusive OR the contents of R and addr and put the result into R. FORMAT=MRGR, OPCODE=43, C=unchanged, L=unchanged, CC=unchanged. #### XH R,addr Exclusive OR Halfword #### RH.XOR.|EA|16→RH Exclusive OR the contents of RH and addr and put the result into RH. **FORMAT**=MRGR, **OPCODE**=53, **C**=unchanged, **L**=unchanged, **CC**=unchanged. #### LOGICAL TEST AND SET—LTSTS #### Logical Test and Set (Logicize) If the test is satisfied, then set the register equal to 1. If the test is not satisfied, then set the register equal to 0. These instructions simplify the analysis of complex logical expressions. The general format is: For example: LCLT R means, if the condition code is less than zero then set R equal to one, else set R equal to zero. | Mnemonic | Function | Opcode | |----------|------------------------------------------------------------------|--------| | LCLT R | If CC $<0$ , then $1 \rightarrow R$ : else $0 \rightarrow R$ | 150 | | LCLE R | If $CC \leq 0$ , then $1 \to R$ ; else $0 \to R$ | 151 | | LCEQ R | If CC=0, then $1 \rightarrow R$ : else $0 \rightarrow R$ | 153 | | LCNE R | If $CC \neq 0$ , then $1 \rightarrow R$ ; else $0 \rightarrow R$ | 152 | | LCGE R | If $CC \ge 0$ , then $1 \to R$ ; else $0 \to R$ | 154 | | LCGT R | If CC>0, then $1 \to R$ ; else $0 \to R$ | 155 | FORMAT=RGEN, C=unchanged, L=unchanged, CC=unchanged. | Mnemonic | Function | Opcode | |----------|----------------------------------------------------------------------|---------| | LLT R | If R<0, then $1 \rightarrow R$ ; else $0 \rightarrow R$ | 000 | | LLE R | If $R \leq 0$ , then $1 \to R$ ; else $0 \to R$ | 001 | | LEQ R | If $R=0$ , then $1 \rightarrow R$ ; else $0 \rightarrow R$ | 003 | | LNE R | If $R\neq 0$ , then $1 \rightarrow R$ ; else $0 \rightarrow R$ | 002 | | LGE R | If $R \geqslant 0$ , then $1 \rightarrow R$ ; else $0 \rightarrow R$ | 004 | | LGT R | If $R>0$ , then $1 \to R$ ; else $0 \to R$ | 005 | | LHLT R | If RH<0, then $1 \rightarrow R$ ; else $0 \rightarrow R$ | 000 | | LHLE R | If $RH \leq 0$ , then $1 \rightarrow R$ ; else $0 \rightarrow R$ | 011 | | LHEQ R | If RH=0, then $1 \rightarrow R$ ; else $0 \rightarrow R$ | 013 | | LHNE R | If $RH \neq 0$ , then $1 \rightarrow R$ ; else $0 \rightarrow R$ | 012 | | LHGE R | If $RH \ge 0$ , then $1 \to R$ : else $0 \to R$ | 004 | | LHGT R | If RH>0, then $1 \rightarrow R$ ; else $0 \rightarrow R$ | 015 | | LFLT R | If $F < 0$ , then $1 \rightarrow R$ ; else $0 \rightarrow R$ | 020,030 | | LFLE R | If $F \leq 0$ , then $1 \to R$ ; else $0 \to R$ | 021,031 | | LFEQ R | If $F=0$ , then $1 \to R$ ; else $0 \to R$ | 023,033 | | LFNE R | If $F\neq 0$ , then $1 \rightarrow R$ ; else $0 \rightarrow R$ | 022,032 | | LFGE R | If $F \ge 0$ , then $1 \to R$ ; else $0 \to R$ | 024,034 | | LFGT R | If $F>0$ , then $1 \to R$ ; else $0 \to R$ | 025,035 | FORMAT=RGEN, C=unchanged, L=unchanged, CC=result. #### LF R Logic set False Set R equal to zero. FORMAT=RGEN, OPCODE=016, C=unchanged, L=unchanged, CC=result. #### LT R Logic set True Set R equal to one. FORMAT=RGEN, OPCODE=017, C=unchanged, L=unchanged, CC= result. #### MACHINE CONTROL—MCTL Defined in Section 11. | CXCS | Control Extended Control Store | |------|--------------------------------| | HLT | Halt | | ITLB | Invalidate STLB entry | | LIOT | Load TLB | | LPID | Load Process ID | | LPSW | Load Program Status Word | | LWCS | Load Writable Control Store | | NOP | No Operation | | PTLB | Purge TLB | | RRST | Restore Registers | | RSAV | Register Save | | STPM | Store Process Model Number | | WCS | Writable Control Store | | XVRY | Verify xis | | | | #### MOVE DATA—MOVE These instructions move data from one location to another. #### I R,addr Interchange Register and Memory—Fullword R⇔|EA|32 Swap the contents of R and addr. FORMAT=MRGR, OPCODE=41, C=unchanged, L=unchanged, CC=unchanged. #### ▶ ICBL R Interchange Bytes and Clear Left $RH(1-8) \Leftrightarrow RH(9-16); 0 \to |RH(1-8)|$ Swap bits 1-8 and bits 9-16 of RH. Then set bits 1-8=0. **FORMAT**=RGEN, **OPCODE**=065, **C** =unchanged, **L**=unchanged, **CC**=unchanged. #### ► ICBR R Interchange Bytes and Clear Right $RH(9-16) \Leftrightarrow RH(1-8); 0 \to RH(9-16)$ Swap bits 9-16 and bits 1-8 of RH. Then set bits 9-16=0. **FORMAT**=RGEN, **OPCODE**=066, **C** =unchanged, **L**=unchanged, **CC**=unchanged. #### ► ICHL R Interchange Halfwords and Clear Left RH⇔RL;0→RH Swap halves of R and set RH=0. **FORMAT**=RGEN, **OPCODE**=060, **C**=unchanged, **L**= unchanged, **CC**=unchanged. #### ICHR R Interchange Register Halfwords and Clear Right RH⇔RL:0→RL Swap halves of R and set RL=0. **FORMAT**=RGEN, **OPCODE**=061, **C**=unchanged, **L**= unchanged, **CC**=unchanged. #### ► IH R,addr Interchange Register and Memory—Halfword RH⇔[EA]16 Swap the contents of RH and addr. FORMAT=MRGR, OPCODE=51, C=unchanged, L=unchanged, CC=unchanged. #### IRB R Interchange Register Bytes $RH(1-8) \Leftrightarrow RH(9-16)$ Swap bits 1-8 of RH with bits 9-16 of RH. **FORMAT**=RGEN, **OPCODE**=064, **C**=unchanged, **L**=unchanged, **CC**=unchanged. #### IRH R Interchange Register Halves RH⇔RL Swap halves of R. FORMAT=RGEN, OPCODE=057, C=unchanged, L=unchanged, CC=unchanged. #### L R,addr Load Fullword [EA]32→R Load the contents of addr into R. FORMAT=MRGR, OPCODE=01, C=unchanged, L=unchanged, CC=unchanged. #### LDAR R,addr Load Addressed Register Stores the contents of R into the register specified by addr. There are three special cases of this instruction which are summarized in Section 11 under LDLR. FORMAT=MRGR, OPCODE=44, C=unchanged, L=unchanged, CC=unchanged. #### LH R,addr Load Halfword [EA]16→RH Load the contents of addr into RH. FORMAT=MRGR, OPCODE=11, C=unchanged, L=unchanged, CC=unchanged. #### LHL1 R,addr Load Halfword Left Shifted by 1 [EA]16.LS.1→RH Left shift the contents of addr by 1 and put the result into RH. FORMAT=MRGR, OPCODE =04, C=unchanged, L=unchanged, CC=unchanged. #### LHL2 R,addr Load Halfword Left Shifted by 2 [EA]16.LS.2→RH Left shift the contents of addr by 2 and put the result into RH. FORMAT=MRGR, OPCODE =14. C=unchanged, L=unchanged, CC=unchanged. #### ST R.addr Store Fullword $R \rightarrow [EA|32]$ Store the contents of R into addr. **FORMAT**=MRGR, **OPCODE**=21, **C**=unchanged, **L**=unchanged, **CC**=unchanged. #### ► STAR R,addr Store Addressed Register Stores the contents of the register specified by the contents of addr into R. There are three special cases of this instruction which are summarized in Section 11 under LDLR. FORMAT =MRGR, OPCODE=54, C=unchanged, L=unchanged, CC=unchanged. #### ► STCD R,addr Store Conditional Fullword If R+1=[EA]32 then $R\rightarrow [EA]32$ If the contents of R+1 equals the contents of addr, then store the contents of R into addr. **FORMAT**=MRGR, **OPCODE**=137, **C**=unchanged, **L**=unchanged, **CC**=result. #### STCH R,addr Store Conditional Halfword If RL=[EA]16 then $RH\rightarrow[EA]16$ If the contents of RL equal the contents of addr, then store the contents of RH into addr. FORMAT=MRGR, OPCODE=136, C=unchanged, L=unchanged, CC=results. #### STH R,addr Store Halfword RH→[EA]16 Store the contents of RH into addr. FORMAT=MRGR, OPCODE=31, C=unchanged, L=unchanged, CC=unchanged. #### PROGRAM CONTROL AND JUMP—PCTLJ These instructions either transfer control to a different location or manipulate effective addresses. They differ from branch instructions in the ability to move across segments. They differ among themselves in the complexity of operations performed and in the handling of the return address. #### EALB addr Effective Address to Link Base EA→LB Store the effective address of addr in the link base register. FORMAT=MRNR, OPCODE=42, C=unchanged, L=unchanged, CC=unchanged. #### ► EAR R, addr Effective Address to Register EA→R Store the effective address of addr in R. **FORMAT**=MRGR, **OPCODE**=63, **C**=unchanged, **L** =unchanged, **CC**=unchanged. # EAXB addr Effective Address to Temporary Base #### EA→XB Store the effective address of addr in the temporary base register. FORMAT=MRNR, OPCODE=52, C=unchanged, L=unchanged, CC=unchanged. #### JMP addr Jump EA→PC Jump to addr. FORMAT=MRNR, OPCODE=51, C=unchanged, L=unchanged, CC=unchanged. #### JSR R,addr Jump to Subroutine PC(16-32)→RH;EA→PC Jump to addr and save the 16-bit word number position of the return address in RH. FORMAT=MRGR, OPCODE=73, C=unchanged, L=unchanged, CC=unchanged. #### ► JSXB addr Jump and Set XB PC→XB:EA→PC Jump to addr and save the full 32-bit return address in XB. **FORMAT**=MRNR. **OPCODE**=61. **C**=unchanged, **L**=unchanged, **CC**=unchanged. #### Summary of instructions defined in section 11 | ARGT | Argument Transfer | |------|--------------------| | CALF | Call Fault Handler | | PCL | Procedure Call | | PRTN | Procedure Return | | STEX | Stack Extend | | SVC | Supervisor Call | #### PROCESS EXCHANGE—PRCEX Defined in Section 11. | INBC | Interrupt Notify | |------|------------------| | INBN | Interrupt Notify | | INEC | Interrupt Notify | | INEN | Interrupt Notify | | NFYB | Notify | | NFYE | Notify | | WAIT | Wait | #### QUEUE MANAGEMENT—QUEUE The instructions provided for queue manipulation are register generics with AP-pointer providing the address to the queue control block. See Section 9 for a description of the queue control block. Data is to or from general register 2 and the results of the operation are given in the condition code bits for later testing. addr refers to a control block in virtual space. The virtual queue control block differs from the physical in that a segment number is provided instead of a physical address. Ring zero privilege is required to manipulate physical queues; any non-ring zero attempt to access physical queues will result in a restrict mode violation fault. Also, the ring number determines the privilege of access into both the control block and the data block. #### ABQ addr Add to Bottom of Queue Add the contents of general register 2 to the bottom of the queue defined by the QCB (Queue Control Block) at addr. The condition codes are set EQ if the queue is full. e.g., the word could not be added. FORMAT=RGEN, OPCODE=134, C=unchanged. L=unchanged. CC= result. # ATQ addr Add to Top of Queue Add the contents of general register 2 to the top of the queue defined by the QCB at addr. The condition codes are set EQ if the queue is full,. e.g., the word could not be added. FORMAT=RGEN, OPCODE=135. C=unchanged, L=unchanged, CC=result. # RBQ addr Remove from Bottom of Queue Remove a single word from the bottom of the queue defined by the QCB at addr. and place it in general register 2. But, if the queue is empty, set general register 2=0 and condition codes EQ. FORMAT=RGEN, OPCODE=133, C=unchanged, L=unchanged, CC=result. # RTQ addr Remove from Top of Queue Remove a single word from the top of the queue defined by the QCB at addr. and place it in general register 2. But if the queue is empty, set general register 2=0 and condition codes EQ. FORMAT=RGEN. OPCODE=132. C=unchanged. L=unchanged. CC=result. # TSTQ addr Test Queue Set general register 2 to the number of items in the queue defined by the QCB at addr. If the queue is empty, set condition codes EQ. **FORMAT**=RGEN. **OPCODE**=104. **C**=unchanged. **L** =unchanged. **CC**=result. #### SHIFT—SHIFT DATA #### Register Shifts #### ROT R,addr Rotate Rotate the bits in R. The low order 16 bits of addr tell how many bits to shift, in what direction and whether full or halfword. Bit 1=0=left Bit 1=1=right Bit 2=0=word (32) Bit 2=1=halfword Bits 3-10=unused Bits 11-16=two's complement of number of bits to shift FORMAT=MRGR. OPCODE=24, C=shift extension, L=unspecified. CC=unchanged. # SHA R, addr Shift Arithmetic Shift R arithmetically. The low order 16 bits of addr tell how many bits to shift, in what direction and whether full or halfword. Bit 1=0=left Bit 1=1=right Bit 2=0=word (32) Bit 2=1=halfword Bits 3-10=unused Bits 11-16=two's complement of number of bits to shift FORMAT=MRGR, OPCODE=15, C=shift extension, L=unspecified, CC=unchanged. # SHL R,addr Shift Logical Shift R logically. The low order 16 bits of addr tell how many bits to shift, in what direction and whether full or halfword. Bit 1=0=left Bit 1=1=right Bit 2=0=word (32) Bit 2=1=halfword Bits 3-10=unused Bits 11-16=two's complement of number of bits to shift FORMAT=MRGR. OPCODE=05. C=shift extension. L=unspecified, CC=unchanged. #### SL1 R Shift Register Left 1 Shift R left one bit logically. FORMAT=RGEN, OPCODE=072. C=shift extension, L=unspecified. CC=unchanged. #### ► SL2 R Shift Register Left 2 Shift R left two bits logically. FORMAT=RGEN, OPCODE=073. C=shift extension. L=unspecified, CC=unchanged. # SR1 R Shift Register Right 1 Shift R right one bit logically. FORMAT=RGEN, OPCODE=074. C=shift extension. L= unspecified, CC=unchanged. # SR2 R Shift Register Right 2 Shift R right two bits logically. FORMAT=RGEN, OPCODE=075, C=shift extension, L= unspecified, CC=unchanged. #### Half Register Shifts # SHL1 R Shift Half Register Left 1 Shift RH left one bit logically. FORMAT=RGEN, OPCODE=076, C=shift extension, L= unspecified, CC=unchanged. # SHL2 R Shift Half Register Left 2 Shift RH left two bits logically. FORMAT=RGEN, OPCODE=077, C=shift extension, L= unspecified, CC=unchanged. #### SHR1 R Shift Half Register Right 1 Shift RH right one bit logically. FORMAT=RGEN, OPCODE=120. C=shift extension, L= unspecified, CC=unchanged. # SHR2 R Shift Half Register Right 2 Shift RH right two bits logically. FORMAT=RGEN. OPCODE=121. C=shift extension. L= unspecified, CC=unchanged. # Instruction summary chart #### **INSTRUCTION SUMMARY** This chart contains a complete list of instructions for the Prime 100 through 500. Each instruction is followed by its octal code, format, function information on addressing mode and hardware availability, and a one line description of the instruction. The columns in the list are as follows: | R | RESTRICTIONS | | | | | | | | | |--------|--------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|--|--|--| | | blank | regular instruction | | | | | | | | | | R | instruction causes a restricted mode fault if executed in other than right $\boldsymbol{0}$ | | | | | | | | | | P | instruction may cause a fault depending on address | | | | | | | | | | W | writable control store instruction, may be programmed in wcs to cause a fault | | | | | | | | | | M | Machine specific—use only on specified CPU. Usually an instruction reserved for operating system, such as EPMJ. | | | | | | | | | MNEM | a mnemonic name recognized by the assembler PMA. | | | | | | | | | | OPCODE | that I/O instru<br>reference and | n code of the instruction. The codes are indented so actions are isolated from generics, and the memory register instructions of the P500 are sorted apart instructions of the P100–400. | | | | | | | | | RI | | nd Immediate (I) forms available (P500 memory ructions only); $Y = YES$ , $N = NO$ . | | | | | | | | | FORM | Format of instr | • / | | | | | | | | | | MNEMONIC | C DEFINITION | | | | | | | | | | GEN | Generic | | | | | | | | | BRAN | Branch | |------|------------------------------------| | IBRN | I-mode Branch | | CHAR | Character | | DECI | Decimal | | PIO | Programmed I/O | | SHFT | Shift | | MR | Memory Reference—non I-mode | | MRFR | Memory Reference—Floating Register | | MRNR | Memory Reference—Non Register | | RGEN | Register Generic | | | | Address Pointer AP #### **FUNC** #### Function of instruction #### MNEMONIC DEFINITION | ADMOD | Addressing Mode | |-------|---------------------------| | BRAN | Branch | | CHAR | Character | | CLEAR | Clear field | | DECI | Decimal Arithmetic | | FIELD | Field Register | | FLOAT | Floating Point Arithmetic | | INT | Integer | | INTGY | Integrity | | IO | Input/Output | | KEYS | Keys | | LOGIC | Logical Operations | | LTSTS | Logical Test and Set | | MCTL | Machine Control | | MOVE | Move | | PCTLJ | Program Control and Jump | | PRCEX | Process Exchange | | QUEUE | Queue Control | | SHIFT | Register Shift | | SKIP | Skip | **MODE** Addressing modes in which instruction functions as defined: - S Sectored - R Relative - V 64V (P400-P500) - I 32I (P500) #### 1 2 3 Column How instruction is implemented - 1 = Prime 100, 200, 300 series - 2 = Prime 400 series - 3 = Prime 500 series Codes are: - Not implemented. Do not use this mnemonic on this CPU. - H Implemented by standard hardware. - O Implemented by hardware option or UII library if option is not present. - U Implemented by UII library - A UII on 100, 200, hardware on 300 - B Optional on 100, 200, hardware on 300 - C Not implemented on 100, optional on 200, 300 - D UII on 100, optional on 200, 300 - E Not implemented on 100, hardware on 200, 300 - F Not implemented on 100, 200, hardware on 300 - G Not implemented on 100, optional on 200, hardware on 300 How instruction affects C and L bits, codes are: - C and L are unchanged - 1 C = unchanged, L = carry - $2 \quad C = overflow status, L = carry$ - 3 C = overflow status, L = unspecified - 4 C = status extension, L = unspecified - 5 C = result, L = unspecified С 6 C = unspecified, L = unspecified 7 C = loaded by instruction, L = loaded by instruction How instruction affects condition codes, codes are: - condition codes are not altered - 1 condition codes are set to reflect the result of arithmetic operation or compare - 4 condition codes are set to reflect result of branch, compare or logicize operand state. - 5 condition codes are indeterminant - 6 condition codes are loaded by instruction - 7 special results are shown in condition codes for this instruc- #### DESCRIPTION CC a brief description of the instruction #### R MNEM OP CODE RI FORM FUNC MODE 1 2 3 C CC DESCRIPTION | A | 02 | YY | MRGR | INT | I | — — H 2 1 Add Fullword | |------------------|------------------|----|--------------|----------------|--------|-----------------------------------------------------------------------------------------------| | A1A | 141206 | | GEN | INT | SRV | H H H 2 1 Add One to A | | A2A | 140304 | | GEN | INT | SRV | H H H 2 1 Add Two to A | | ABQ<br>ABQ | 141716<br>134 | | AP<br>AP | QUEUE<br>QUEUE | V<br>I | - H H - 7 Add to Bottom of Queue - H - 7 Add to Bottom of Queue | | ACA | 141216 | | GEN | INT | SRV | H H H 2 1 Add C-Bit to A | | ADD | 06 | | MR | INT | SRV | H H H 2 1 Add | | ADL | 06 03 | | MR | INT | v | — H H 2 1 Add Long | | ADLL | 141000 | | GEN | INT | v | — H H 2 1 Add Link Bit to L | | ADLR | 014 | YY | RGEN | INT | I | — — H 2 1 Add Link to R | | AH | 12 | | MRGR | INT | I | — — H 2 1 Add Halfword | | ALFA 0<br>ALFA 1 | 001301<br>001311 | | GEN<br>GEN | FIELD<br>FIELD | v<br>v | <ul> <li>H H 6 5 Add L to Field Address</li> <li>H H 6 5 Add L to Field Address</li> </ul> | | ALL | 0414XX | | SHFT | SHIFT | SRV | H H H 4 — A Left Logical | | ALR | 0416XX | | SHFT | SHIFT | SRV | H H H 4 — A Left Rotate | | ALS | 0415XX | | SHFT | SHIFT | SRV | H H H 2 — A Left Shift | | ANA | 03 | | MR | LOGIC | SRV | H H H — — AND | | ANL<br>ARFA 0 | 03 03<br>161 | | MR<br>RGEN | LOGIC<br>FIELD | V<br>I | <ul> <li>H H — — AND Long</li> <li>H 6 — Add R to Field Address</li> </ul> | | ARFA 1 | 171 | | RGEN | FIELD | I | — — H 6 — Add R to Field Address | | ARGT | 000605 | | GEN | PCTLJ | VI | — H H 6 5 Argument Transfer | | ARL | 0404XX | | SHFT | SHIFT | SRV | H H H 4 — A Right Logical | | ARR | 0406XX | | SHFT | SHIFT | SRV | H H H 4 — A Right Rotate | | ARS | 0405XX | | SHFT | SHIFT | SRV | H H H 4 — A Right Shift | | ATQ | 141717 | | AP | QUEUE | V | — H H — 7 Add to Top of Queue | | ATQ | 135 | | AP | QUEUE | I | — — H — 7 Add to Top of Queue | | BCEQ | 141602 | | BRAN | Bran | VI | — H H — — Branch if CC = 0 | | BCGE | 141605 | | BRAN | BRAN | VI | $-$ H H $ -$ Branch if CC $\geqslant$ 0 | | BCGT | 141601 | | BRAN | BRAN | VI | - H H $ -$ Branch if CC $>$ 0 | | BCLE | 141600 | | BRAN | BRAN | VI | $-$ H H $ -$ Branch if $CC \le 0$ | | BCLT | 141604 | | BRAN | BRAN | VI | - H H $ -$ Branch if $CC < 0$ | | BCNE | 141603 | | BRAN | BRAN | VI | — H H — — Branch if CC •NE • 0 | | BCR | 141705 | | BRAN | BRAN | VI | — H H — — Branch if C-Bit = 0 | | BCS | 141704 | | BRAN | BRAN | VI | - H H Branch if C-Bit = 1 | | BDX | 140734 | | BRAN | BRAN | V | - H H - Decrement X and branch if X •NE• 0 | | BDY<br>BEQ | 140724<br>140612 | | BRAN<br>BRAN | BRAN<br>BRAN | V<br>V | <ul> <li>H H — Decrement Y and branch if Y •NE• 0</li> <li>H H — 4 Branch if A = 0</li> </ul> | | BFEQ | 141612 | | BRAN | BRAN | V | — H H — 4 Branch if F = 0 | | BFEQ | 122 | | IBRN | BRAN | I | — H — 4 Branch if F = 0 | | BFGE | 141615 | | BRAN | BRAN | V | $-$ H H $-$ 4 Branch if F $\geqslant$ 0 | | BFGE | 125 | | IBRN | BRAN | I | $-$ H $-$ 4 Branch if F $\geqslant$ 0 | | BFGT<br>BFGT | 141611<br>121 | | BRAN<br>IBRN | BRAN<br>BRAN | V<br>Ī | <ul> <li>H H — 4 Branch if F &gt; 0</li> <li>H — 4 Branch if F &gt; 0</li> </ul> | | BFLE | 141610 | | BRAN | BRAN | V | $-$ H H $-$ 4 Branch if $F \le 0$ | | BFLE | 120 | | IBRN | BRAN | I | $-$ H $-$ 4 Branch if $F \le 0$ | 1 March, 1979 13–3 FDR 3059 | ] | BFLT | 141614 | | BRAN | BRAN | V | | Η | Н | _ | 4 | Branch if $F < 0$ | |---|------|------------------|----|------|-------|----------|---|--------|---|---|---|----------------------------------------------------| | | BFLT | 124 | | IBRN | BRAN | I | _ | _ | Н | _ | 4 | Branch if $F < 0$ | | ] | BFNE | 141613 | | BRAN | BRAN | V | _ | Н | Н | _ | 4 | Branch if F •NE• 0 | | | BFNE | 123 | | IBRN | BRAN | I | _ | _ | Η | _ | 4 | Branch if F •NE• 0 | | ; | BGE | 140615 | | BRAN | BRAN | V | _ | Н | Н | - | 4 | Branch if $A \geqslant 0$ | | | BGT | 140611 | | BRAN | BRAN | V | _ | Η | Н | _ | 4 | Branch if A > 0 | | | BHD1 | 144 | | IBRN | BRAN | I | | _ | Н | _ | _ | Decrement H by One; Branch if H •NE• 0 | | | BHD2 | 145 | | IBRN | BRAN | I | _ | _ | Η | _ | _ | Decrement H by Two; Branch if H •NE• 0 | | | BHD4 | 146 | | IBRN | BRAN | I | _ | | Н | | | Decrement H by Four; Branch if H •NE• 0 | | | BHEQ | 112 | | IBRN | BRAN | I | _ | _ | Η | _ | 4 | Branch if H = 0 | | | BHGE | 105 | | IBRN | BRAN | I | _ | _ | Н | _ | 4 | Branch if $H \geqslant 0$ | | | BHGT | 111 | | IBRN | BRAN | I | _ | _ | Н | | 4 | Branch if H > 0 | | | BHI1 | 140 | | IBRN | BRAN | I | _ | _ | Н | _ | _ | Increment H by One; Branch if H •NE• 0 | | | BHI2 | 141 | | IBRN | BRAN | I | _ | _ | Н | _ | _ | Increment H by Two; Branch if H •NE• 0 | | | BHI4 | 142 | | IBRN | BRAN | I | _ | _ | Н | _ | _ | Increment H by One; Branch if H •NE• 0 | | | BHLE | 110 | | IBRN | BRAN | I | _ | _ | Н | _ | 4 | Branch if $H \leq 0$ | | | BHLT | 104 | | IBRN | BRAN | I | _ | _ | Н | _ | 4 | Branch if H < 0 | | | BHNE | 113 | | IBRN | BRAN | I | _ | _ | Н | _ | 4 | Branch if H is not equal to 0 | | | BIX | 141334 | | BRAN | BRAN | v | _ | Н | Н | _ | _ | Increment X and Branch if X •NE• 0 | | | BIY | 141324 | | BRAN | BRAN | v | | Н | Н | _ | | Increment Y and Branch if Y •NE• 0 | | | BLE | 140610 | | BRAN | BRAN | V | _ | Н | Н | _ | 4 | Branch if A ≤ 0 | | | BLEQ | 140010 | | BRAN | BRAN | v | | Н | Н | _ | 4 | Branch if L = 0 | | | - | | | BRAN | BRAN | v | _ | Н | Н | _ | 4 | Branch is L ≥ 0 | | | BLGE | 140615<br>140701 | | BRAN | BRAN | v | _ | Н | Н | _ | 4 | Branch if L > 0 | | | BLGT | | | | BRAN | v | _ | Н | н | _ | 4 | Branch if L ≤ 0 | | | BLLE | 140700 | | BRAN | BRAN | V | _ | Н | Н | _ | 4 | Branch if L < 0 | | | BLLT | 140614 | | BRAN | BRAN | v | _ | Н | Н | _ | 4 | Branch if L •NE• 0 | | | BLNE | 140703 | | BRAN | | V<br>VI | _ | Н | Н | _ | - | Branch if L-Bit = 0 | | | BLR | 141707 | | BRAN | BRAN | VI | _ | Н | Н | _ | | Branch if L-Bit = 1 (Set) | | | BLS | 141706 | | BRAN | BRAN | V | _ | Н | Н | _ | | Branch if $A < 0$ | | | BLT | 140614 | | BRAN | BRAN | | | | | | | | | | BMEQ | 141602 | | BRAN | BRAN | VI<br>VI | _ | H<br>H | Н | _ | | Branch if Magnitude = 0 Branch if Magnitude is ≥ 0 | | | BMGE | 141706 | | BRAN | BRAN | | _ | | | | | - | | | BMGT | 141710 | | BRAN | BRAN | VI | _ | Н | Н | _ | | <del>-</del> | | | BMLE | 141711 | | BRAN | BRAN | VI | | Н | Н | | _ | Branch if Magnitude is ≤ 0 | | | BMLT | 141707 | | BRAN | BRAN | VI | _ | Н | Н | _ | | Branch if Magnitude is < 0 | | | BMNE | 141603 | | BRAN | BRAN | VI | _ | Н | Н | | _ | Branch if Magnitude is •NE• 0 Branch if A •NE• 0 | | | BNE | 140613 | | BRAN | BRAN | V | | Н | Н | | 4 | | | | BRBR | 040-077 | | IBRN | BRAN | I | _ | | Н | | | Branch if R bit n = 0 | | | BRBS | 000-037 | | IBRN | BRAN | I | _ | _ | | | | Branch if R bit n = 1 | | | BRD1 | 134 | | IBRN | BRAN | I | | | | _ | | Decrement R by One; Branch if R •NE• 0 | | | BRD2 | 135 | | IBRN | BRAN | I | _ | | Н | | _ | Decrement R by Two; Branch if R •NE• 0 | | | BRD4 | 136 | | IBRN | BRAN | I | | _ | Н | | | • | | | BREQ | 102 | | IBRN | BRAN | I | _ | _ | Н | _ | 4 | Branch if R = 0 | | | BRGE | 105 | | IBRN | BRAN | I | | _ | Н | | | Branch if $R \ge 0$ | | | BRGT | 101 | | IBRN | BRAN | I | _ | _ | | _ | 4 | Branch if R > 0 | | | BRI1 | 130 | | IBRN | BRAN | I | _ | _ | | | | Increment R by one and branch if •NE• 0 | | | BRI2 | 131 | | IBRN | BRAN | I | _ | _ | | _ | | Increment R by 2 and branch if •NE• 0 | | | BRI4 | 132 | | IBRN | BRAN | I | | | | | | Increment R by 4 and branch if •NE• 0 | | | BRLE | 100 | | IBRN | BRAN | I | _ | _ | Н | _ | 4 | Branch if R ≤ 0 | | | BRLT | 104 | | IBRN | BRAN | I | _ | _ | | | | Branch if R < 0 | | | BRNE | 103 | | IBRN | BRAN | I | _ | | | _ | 4 | Branch if R •NE• 0 | | | С | 61 | YY | MRGR | | I | | _ | Н | | 1 | Compare Fullword | | R | CAI | 000411 | | GEN | IO | SRVI | Н | Н | Н | | _ | Clear Active Interrupt | | | CAL | 141050 | | GEN | CLEAR | SRV | Н | Н | Н | | _ | Clear A Left | | | CALF | 000705 | | AP | PCTLJ | VI | _ | Н | Н | | 5 | Call Fault Handler | | | CAR | 141044 | | GEN | CLEAR | SRV | Н | Н | Н | | | Clear A Right Byte | | | CAS | 11 | | MR | SKIP | SRV | Н | Н | Н | | 1 | Compare A and Skip | | | CAZ | 140214 | | GEN | SKIP | SRV | | Н | | | 1 | Compare A with Zero | | | CEA | 000111 | | GEN | PCTLJ | SR | Н | Н | Н | | | Compute Effective Address | | | CGT | 001314 | | GEN | BRAN | v | _ | Н | | | 5 | Computed GOTO | | | CGT | 026 | | RGEN | | I | | _ | | | | Computed GOTO | | | CH | 71 | YY | MRGR | INT | I | _ | | Н | | 1 | Compare Halfword | | | CHS | 140024 | | GEN | INT | SRV | Н | Н | Н | _ | _ | Change Sign | | | | | | | | | | | | | | | | | CHS | 040 | | RGEN | INT | I | | _ | Н | _ | _ | Change Sign | |----|-------------|-----------------|------|-------------|----------------|--------------|--------|--------|--------|--------|--------|-----------------------------------------------| | | CLS | 11 03 | | MR | LOGIC | $\mathbf{v}$ | _ | Н | Н | 1 | 1 | Compare L and Skip | | | CMA | 140401 | | GEN | LOGIC | SRV | Н | Н | Η | _ | _ | Complement A | | | CMH | 045 | | RGEN | LOGIC | I | _ | _ | Н | _ | _ | Complement H | | | CMR | 44 | | RGEN | LOGIC | I | - | | Н | | _ | Complement R | | | CR | 056 | | RGEN | CLEAR | I | _ | _ | Н | _ | _ | Clear | | | CRA | 140040 | | GEN | CLEAR | SRV | Н | Н | Н | | _ | Clear A | | | CRB | 140015 | | GEN | CLEAR | SRV | Н | Н | Н | _ | _ | Clear B | | | CRBL | 062 | | RGEN | CLEAR | I | _ | | Н | | _ | Clear High Byte 1 Left | | | CRBR | 063 | | RGEN | CLEAR | I | _ | | Н | | _ | 0 2 0 | | | CRE | 141404 | | GEN | CLEAR | V | _ | Н | H | | | Clear E | | | CREP | 10 02 | | MR | PCTLJ | R | A | Н | Н | | | Call Recursive Entry Procedure | | | CRHL | 054 | | RGEN | CLEAR | I | _ | _ | Н | | | Clear Left Half Register | | | CRHR | 055 | | RGEN | CLEAR | I | _ | _ | Н | | | Clear Right Half Register | | | CRL | 140010 | | GEN | CLEAR | SRV | Н | H | Н | | | Clear L | | | CRLE | 141410 | | GEN | CLEAR | V | _ | Н | Н | _ | | <del></del> | | | CSA<br>CSR | 140320 | | GEN | MOVE<br>MOVE | SRV<br>I | H<br>— | H<br>— | H<br>H | 5 | _ | Copy Sign of A | | р | CXCS | 041<br>001714 | | RGEN<br>GEN | MCTL | VI | _ | H | Н | 5<br>6 | _<br>5 | Copy Sign of R Control Extended Control Store | | Λ. | D | 62 | YY | MRGR | | I | | | Н | 3 | 5 | Divide Fullword | | | DAD | 06 | | MR | INT | SR | В | Н | Н | 2 | 1 | Double Add | | | DBL | 000007 | | GEN | INT | SR | Н | Н | Н | _ | _ | Enter Double Precision Mode | | | DBLE | 106 | | RGEN | FLPT | I | _ | _ | Н | _ | | Convert Single to Double Float | | | DFA | 15,17 | YY | MRFR | FLPT | I | _ | _ | Н | 3 | 5 | Double Floating Add | | | DFAD | 06 02 | | MR | FLPT | RV | Α | Н | Н | 3 | 5 | Double Floating Add | | | DFC | 05,07 | YY | MRFR | FLPT | I | _ | _ | Н | _ | 1 | Double Floating Compare | | | DFCM | 140574 | | GEN | FLPT | RV | С | Н | Н | 3 | 5 | Double Floating Complement | | | DFCM | 144 | | RGEN | FLPT | I | _ | _ | Н | 3 | 5 | Double Floating Complement | | | DFCS | 11 02 | | MR | FLPT | RV | Α | Н | Н | 6 | 5 | Double Floating Compare and Skip | | | DFD | 31,33 | YY | MRFR | FLPT | I | _ | _ | Н | 3 | 5 | Double Floating Divide | | | DFDV | 17 02 | | MR | FLPT | RV | D | Н | Н | 3 | 5 | Double Floating Divide | | | DFL | 01,03 | YY | MRFR | FLPT | I | | _ | Н | _ | _ | Double Floating Load | | | DFLD | 02 02 | | MR | FLPT | RV | Α | Н | Н | _ | _ | Double Floating Load | | | DFLX | 15 02 | | MR | FLPT | V | _ | Н | Н | _ | _ | Load Double Floating Index | | | DFM | 25,27 | ΥY | MRFR | FLPT | I | _ | _ | Н | 3 | 5 | Double Floating Multiply | | | DFMP | 16 02 | | MR | FLPT | RV | D | Η | Н | 3 | 5 | Double Floating Multiply | | | DFS | 21,23 | ΥY | MRFR | FLPT | I | _ | _ | Н | 3 | 5 | Double Floating Subtract | | | DFSB | 07 02 | NINI | MR | FLPT | RV<br>I | A | H<br>— | H<br>H | 3 | 5 | Double Floating Subtract | | | DEST | 11,13 | NN | MRFR<br>MR | FLPT | RV | _ | Н | | _ | _ | Double Floating Store | | | DFST<br>DH | 04 02<br>72 | YY | MRGR | FLPT<br>INT | I | A | _ | H<br>H | 3 | _<br>5 | Double Floating Store Divide Halfword | | | DH1 | 130 | 1 1 | RGEN | INT | I | | | Н | 2 | 1 | Decrement H by 1 | | | DH2 | 131 | | RGEN | INT | I | _ | _ | Н | 2 | 1 | Decrement H by 2 | | | DIV | 17 | | MR | INT | V | _ | Н | Н | 3 | 5 | Divide | | | DIV | 17 | | MR | INT | SR | В | Н | Н | 3 | 5 | Divide | | | DLD | 02 | | MR | MOVE | SR | В | Н | Н | _ | | Double Load | | | DM | 60 | NN | MRNR | | I | _ | _ | Н | _ | 1 | Decrement Fullword | | | DMH | 70 | NN | MRNR | INT | I | | _ | Н | _ | 1 | Decrement Halfword | | | DR1 | 124 | | RGEN | INT | I | _ | _ | Н | 2 | 1 | Decrement R by One | | | DR2 | 125 | | RGEN | INT | I | _ | _ | Н | 2 | 1 | Decrement R by Two | | | DRX | 140210 | | GEN | SKIP | SRV | Н | Н | Н | _ | _ | Decrement and Replace X | | | DSB | 07 | | MR | INT | SR | В | Н | Н | 2 | 1 | Double Subtract | | | DST | 04 | | MR | MOVE | SR | В | Н | Н | _ | _ | | | | DVL | 17 03 | | MR | INT | V | _ | Н | Н | 3 | 5 | 3 | | | E16S | 000011 | | GEN | ADMOD | SRVI | Н | Н | Н | _ | _ | Enter 16S Mode | | | E32I | 001010 | | GEN | ADMOD | | _ | | | | | Enter 32I Mode | | | E32R | 001013 | | GEN | ADMOD | | Н | Н | | | | Enter 32R Mode | | | E32S | 000013 | | GEN | ADMOD | | | Н | Н | | | Enter 32S Mode Enter 64R Mode | | | E64R | 001011 | | GEN | ADMOD<br>ADMOD | | Н — | Н | | | | Enter 64K Mode Enter 64V Mode | | | E64V<br>EAA | 000010<br>01 01 | | GEN<br>MR | MOVE | R | A | Н | | | | Effective Address to A | | | EAFA 0 | 001300 | | AP | FIELD | VI | | | | | | Effective Address to Field Address | | | | 307000 | | | . 1000 | •• | _ | | | | | Register 0 | | | | | | | | | | | | | | g | | R | MNEM | OP CODE | RI | FORM | FUNC | MODE | 1 | 2 | 3 | C | СC | DESCRIPTION | |--------|--------------|----------------------|----|--------------|----------------|--------------|----------|----------|--------|--------|--------|-----------------------------------------------------------------------| | | EAFA 1 | 001310 | | AP | FIELD | VI | _ | Н | Ĥ | - | - | Effective Address to Field Address | | | EAL<br>EALB | 01 01<br>42 | NN | MR<br>MRNR | PCTLJ<br>PCTLJ | V<br>I | _ | H | H<br>H | _ | _ | Register 1 Effective Address to L Effective Address to LB | | | EALB<br>EAR | 13 02<br>63 | NN | MR<br>MRGR | PCTLI<br>PCTLI | V<br>I | _ | H | H<br>H | | _ | Effective Address to LB Effective Address to R | | | EAXB<br>EAXB | 52<br>12 02 | NN | MRNR<br>MR | PCTLJ<br>PCTLJ | I<br>V | _ | <u></u> | H<br>H | | _ | Effective Address to XB Effective Address to XB | | R<br>R | EIO<br>EIO | 34<br>14 01 | NN | MRGR<br>MR | IO<br>IO | I<br>V | _ | _<br>H | H<br>H | _ | 7<br>7 | Execute I/O Execute I/O | | R<br>R | EMCM<br>ENB | 000503<br>000401 | | GEN<br>GEN | INTGY<br>IO | SRVI<br>SRVI | E<br>H | H<br>H | | | | Enter Machine Check Mode<br>Enable Interrupts | | | ENTR<br>EPMJ | 01 03<br>000217 | | MR<br>MR | PCTLJ<br>MCTL | R<br>SR | A<br>H | H<br>— | H<br>— | _ | | Enter Recursive Procedure Stack<br>Enter Paging Mode and Jump | | R | EPMX<br>ERA | 00023 <i>7</i><br>05 | | MR<br>MR | MCTL<br>LOGIC | SR<br>SRV | H<br>H | _<br>H | _<br>H | _ | _ | Enter Paging Mode and Jump to XCS Exclusive OR to A | | R | ERL<br>ERMJ | 05 03<br>000701 | | MR<br>MR | LOGIC<br>MCTL | V<br>SR | _<br>H | Н<br>— | | | _ | Exclusive OR to L<br>Enter Restricted Execution Mode | | R | ERMX | 000721 | | MR | MCTL | SR | Н | _ | _ | _ | _ | and Jump<br>Enter Restricted Execution Mode | | R | ESIM | 000415 | | GEN | IO | SRVI | Н | Н | Н | _ | _ | and Jump to WCS<br>Enter Standard Interrupt Mode | | R<br>R | EVIM<br>EVMJ | 000417<br>000703 | | GEN<br>MR | IO<br>MCTL | SRVI<br>SR | H<br>F | H | H<br>— | _ | _ | Enter Vectored Interrupt Mode<br>Enter Vectored Mode and Jump | | R | EVMX<br>FA | 000723<br>14,16 | YY | MR<br>MRFR | MCTL<br>FLPT | SR<br>I | F | _ | —<br>Н | _<br>3 | _<br>5 | Enter Virtual Mode and Jump to WCS Floating Add | | | FAD<br>FC | 06 01<br>04,06 | ΥY | MR<br>MRFR | FLPT<br>FLPT | RV<br>I | A<br>— | H<br>— | H<br>H | 3 | 5<br>1 | Floating Add<br>Floating Compare | | | FCM<br>FCM | 140530<br>100 | | GEN<br>RGEN | FLPT<br>FLPT | RV<br>I | C | H<br>— | H<br>H | 3 | 5<br>5 | Floating Complement<br>Floating Complement | | | FCS<br>FD | 11 01<br>30,32 | YY | MR<br>MRFR | FLPT<br>FLPT | RV<br>I | A<br>— | H<br>— | H<br>H | 6<br>3 | 5<br>5 | Floating Compare and Skip<br>Floating Divide | | | FDBL<br>FDV | 140016<br>17 01 | | GEN<br>MR | FLPT<br>FLPT | V<br>RV | _<br>D | H<br>H | H<br>H | _<br>3 | _<br>5 | Convert Single to Double Float<br>Floating Divide | | | FL<br>FLD | 00,02<br>02 01 | YY | MRFR<br>MR | FLPT<br>FLPT | I<br>RV | _<br>A | _<br>H | H<br>H | _ | _ | Floating Load<br>Floating Load | | | FLOT<br>FLT | 140550<br>105,115 | | GEN<br>RGEN | FLPT<br>FLPT | R<br>I | <u>C</u> | <u>H</u> | H<br>H | 3<br>3 | 5<br>5 | Convert 31-Bit Integer to Float<br>Convert Integer to Floating | | | FLTA<br>FLTH | 140532<br>102,112 | | GEN<br>RGEN | FLPT<br>FLPT | V<br>I | _ | H<br>— | H<br>H | 3<br>3 | 5<br>5 | Convert Integer to Floating<br>Convert Halfword to Floating | | | FLTL<br>FLX | 140535<br>15 01 | | GEN<br>MR | FLPT<br>FLPT | V<br>RV | _<br>A | H<br>H | H<br>H | 3 | 5 | Convert Long Integer to Floating<br>Load Double Word Index | | | FM<br>FMP | 24,26<br>16 01 | YY | MRFR<br>MR | FLPT<br>FLPT | I<br>RV | _<br>D | —<br>Н | H<br>H | 3<br>3 | 5<br>5 | Floating Multiply<br>Floating Multiply | | | FRN<br>FRN | 140534<br>107 | | GEN<br>RGEN | FLPT<br>FLPT | RV<br>I | D<br>_ | H<br>— | H<br>H | 3<br>3 | 5<br>5 | Floating Round<br>Floating Round | | | FS<br>FSB | 20,22<br>07 01 | YY | MRFR<br>MR | FLPT<br>FLPT | I<br>RV | _<br>A | _<br>H | H<br>H | 3<br>3 | 5<br>5 | Floating Subtract<br>Floating Subtract | | | FSGT<br>FSLE | 140515<br>140514 | | GEN<br>GEN | FLPT<br>FLPT | RV<br>RV | C | H<br>H | H<br>H | _ | | Floating Skip if > 0<br>Floating Skip ≤ 0 | | | FSMI<br>FSNZ | 140512<br>140511 | | GEN<br>GEN | FLPT<br>FLPT | RV<br>RV | C | H<br>H | H<br>H | | _ | Floating Skip if Minus<br>Floating Skip if Not Zero | | | FSPL<br>FST | 140513<br>10,12 | NN | GEN<br>MRFR | FLPT<br>FLPT | RV<br>I | <u>C</u> | <u>н</u> | H<br>H | 3 | _ | Floating Skip if Plus<br>Floating Store | | | FST<br>FSZE | 04 01<br>140510 | | MR<br>GEN | FLPT<br>FLPT | RV<br>RV | A<br>C | H<br>H | H<br>H | 3 | _ | Floating Store<br>Floating Skip if Zero | | R | HLT<br>I | 000000<br>41 | YN | GEN<br>MRGR | MCTL<br>MOVE | SRVI<br>I | H<br>— | <u>н</u> | H<br>H | | _ | Halt<br>Interchange Register and Memory- | | | IAB | 000201 | | GEN | MOVE | SRV | Н | Н | Н | _ | | Fullword<br>Interchange A and B | | | ICA | 141340 | | GEN | MOVE | SRV | Н | Н | Н | _ | | Interchange Characters in A | | | ICBL<br>ICBR | 065<br>066 | | RGEN<br>RGEN | MOVE<br>MOVE | I<br>I | _ | _ | H | | _ | Interchange Bytes and Clear Left<br>Interchange Bytes and Clear Right | | R | MNEM | OP CODE | RI | FORM | FUNC | MODE | 1 | 2 | 3 | С | CC | DESCRIPTION | |--------|--------------|------------------------|----|--------------|----------------|--------------|----------|----------|-------------|--------|--------|---------------------------------------------------------------------| | | ICHL | 060 | | RGEN | MOVE | I | _ | _ | Н | _ | _ | Interchange Halves and Clear Left | | | ICHR<br>ICL | 061<br>141140 | | RGEN<br>GEN | MOVE<br>MOVE | I<br>SRV | —<br>Н | —<br>Н | H | | _ | Interchange Halves and Clear Right<br>Interchange and Clear Left | | | ICR<br>IH | 141240<br>51 | YN | GEN<br>MRGR | MOVE<br>MOVE | SRV<br>I | H<br>— | H | H<br>H | _ | | Interchange and Clear Right<br>Interchange Register and Memory | | | IH1<br>IH2 | 126<br>127 | | RGEN<br>RGEN | INT<br>INT | I<br>I | _ | _ | H<br>H | 2 2 | 1 | Halfword Increment by One Increment by Two | | | ILE<br>IM | 141414<br>40 | NN | GEN<br>MRNR | MOVE | V<br>I | _ | Н | Н | | _ | Interchange L and E | | | IMA<br>IMH | 13<br>50 | | MR<br>MRNR | MOVE | SRV<br>I | H | H | H<br>H<br>H | _ | _ | Increment Fullword Interchange Memory and A Increment Halfword | | R<br>R | INA<br>INBC | 54<br>001217 | | PIO<br>AP | IO<br>PRCEX | SR<br>VI | H | H<br>H | H<br>H | _<br>6 | _<br>5 | Input to A Interrupt Notify | | R<br>R | INBN<br>INEC | 001215<br>001216 | | AP<br>AP | PRCEX<br>PRCEX | VI<br>VI | _ | H<br>H | H<br>H | 6<br>6 | 5<br>5 | Interrupt Notify Interrupt Notify | | R<br>R | INEN<br>INH | 001214<br>001001 | | AP<br>GEN | PRCEX<br>IO | VI<br>SRVI | —<br>Н | H<br>H | H<br>H | 6<br>— | 5<br>— | Interrupt Notify Inhibit Interrupts | | | INK<br>INK | 000043<br>070 | | GEN<br>RGEN | KEYS<br>KEYS | SR<br>I | H | H | H<br>H | | _ | Input Keys<br>Save Keys | | | INT<br>INT | 140554<br>103,113 | | GEN<br>RGEN | FLPT<br>FLPT | R<br>I | <u>C</u> | H<br>— | H<br>H | 3<br>3 | 5<br>5 | Convert Floating to Integer<br>Convert Floating to Integer | | | INTA<br>INTH | 140531<br>101,111 | | GEN<br>RGEN | FLPT<br>FLPT | V<br>I | _ | H<br>— | H<br>H | 3<br>3 | 5<br>5 | Convert Floating to Integer<br>Convert Floating to Halfword Integer | | | INTL<br>IR1 | 140533<br>122 | | GEN<br>RGEN | FLPT<br>INT | V<br>I | _ | H<br>— | H<br>H | 3<br>2 | 5<br>1 | Convert Floating to Integer Long<br>Increment R by One | | | IR2<br>IRB | 123<br>064 | | RGEN<br>RGEN | INT<br>MOVE | I<br>I | _ | _ | H<br>H | 2<br>— | 1 | Increment R by Two<br>Interchange Bytes | | | IRH<br>IRS | 057<br>12 | | RGEN<br>MR | MOVE<br>SKIP | I<br>SRV | _<br>H | <u>H</u> | H<br>H | | | Interchange Halves<br>Increment Memory Replace and Skip | | | IRTC<br>IRTN | 000603<br>000601 | | GEN<br>GEN | IO<br>IO | VI<br>VI | _ | H<br>H | H<br>H | 7<br>7 | 6<br>6 | Interrupt Return<br>Interrupt Return | | R | IRX<br>ITLB | 140114<br>000615 | | GEN<br>GEN | SKIP<br>MCTL | SRV<br>VI | H | H<br>H | H<br>H | _ | _ | Increment and Replace X Invalidate STLB entry | | | JDX<br>JEQ | 15 02<br>02 03 | | MR<br>MR | PCTLJ<br>PCTLJ | R<br>R | A<br>A | H<br>H | H<br>H | _ | _ | Jump and Decrement X Jump if = 0 | | | JGE<br>JGT | 07 03<br>05 03 | | MR<br>MR | PCTLJ<br>PCTLJ | R<br>R | A<br>A | H<br>H | H<br>H | _ | _ | Jump if ≥ 0<br>Jump if > 0 | | | JIX<br>JLE | 15 03<br>04 03 | | MR<br>MR | PCTLJ<br>PCTLJ | R<br>R | A<br>A | H<br>H | | | | Jump and Increment $X$ Jump if $\leqslant 0$ | | | JLT<br>JMP | 06 03<br>51 | NN | MR<br>MRNR | PCTLJ<br>PCTLJ | R<br>I | A<br>— | H<br>— | | _ | | Jump if < 0<br>Jump | | | JMP<br>JNE | 01<br>03 03 | | MR<br>MR | PCTLJ<br>PCTLJ | SRV<br>R | H<br>A | H<br>H | H<br>H | _ | _ | Jump<br>Jump if •NE• 0 | | | JSR<br>JST | 73<br>10 | NN | MRGR<br>MR | PCTLJ<br>PCTLJ | I<br>SRV | _<br>H | —<br>Н | H<br>H | _ | _ | Jump to Subroutine<br>Jump and Store PC | | | JSX<br>JSXB | 35 03<br>61 | NN | MR<br>MRNR | PCTLJ<br>PCTLJ | RV<br>I | Н<br>— | H<br>— | H<br>H | _ | _ | Jump and Store Return in X<br>Jump and Store Return in XB | | | JSXB<br>JSY | 14 02<br>14 | | MR<br>MR | PCTLJ<br>PCTLJ | $\mathbf{v}$ | _ | Н | Н | _ | _ | Jump and Store Return in XB<br>Jump and Store Return in Y | | | L<br>LCEQ | 01<br>141503 | YY | | MOVE<br>LTSTS | I<br>V | _ | H | н | | _ | Load<br>Test CC Equal to 0 and Set A | | | LCEQ<br>LCGE | 153<br>141504 | | | LTSTS<br>LTSTS | V<br>V | _ | —<br>Н | | _ | _ ' | Test CC = 0 and Set R<br>Test CC ≥ 0 and Set A | | | LCGE<br>LCGT | 154<br>141505 | | | LTSTS<br>LTSTS | I<br>V | _ | —<br>Н | H · | | | Test CC ≥ 0 and Set R<br>Test CC > 0 and Set A | | | LCGT<br>LCLE | 155<br>1415 <b>0</b> 1 | | | LTSTS<br>LTSTS | I<br>V | | <u>—</u> | Н -<br>Н | | _ ' | Test $CC > 0$ and $Set R$<br>Test $CC \le 0$ and $Set A$ | | | LCLE<br>LCLT | 151<br>141500 | | | LTSTS<br>LTSTS | I<br>V | _ | | H · | _ | _ ′ | Test CC ≤ 0 and Set R<br>Test CC < 0 and Set A | | | LCLT<br>LCNE | 150<br>141502 | | | LTSTS<br>LTSTS | I<br>V | | | H<br>H | | _ ; | Fest CC < 0 and Set R<br>Test CC •NE• 0 and Set A | | 1 | LCNE | 152 | | RGEN | LTSTS | I | _ | _ | н - | | - : | Test CC •NE• 0 and Set R | ``` SRV H H H - - Load A MR MOVE LDA 02 - H - - Load From Addressed Register NN MRGR MOVE I LDAR 44 - H - 7 Load Character RGEN CHAR I LDC 0 162 - H - 7 Load Character LDC 1 172 RGEN CHAR I H H - 7 Load Character CHAR CHAR LDC 0 001302 H H - 7 Load Character CHAR V LDC 1 001312 CHAR Н H - - Load Long v MOVF. LDL 02 03 MR MOVE v Н Н Load From Addressed Register MR LDLR 05 01 MR MOVE SRV Н Н H - - Load X I.DX 35 н — — Load Y Н MOVE v LDY 35 01 MR H H H - 4 Test A = 0: Set A LTSTS SRV GEN LEQ 140413 н — Test R = 0; Set R 4 RGEN LTSTS LEQ 003 H H H - 4 Logic Set A False GEN LTSTS LF 140416 H - 4 Logic Set R False LF RGEN LTSTS I _ 016 Н Н Test F = 0: Set A V 141113 GEN LTSTS LFEQ 4 Test F = 0; Set R RGEN LTSTS Н LFEQ 023,033 Н Test F \ge 0: Set A GEN LTSTS V н — 4 LFGE 141114 Test F ≥ 0; Set R Н 4 RGEN LTSTS I LFGE 024,034 H H - 4 Test F > 0; Set A LTSTS LFGT 141115 GEN H - 4 Test F > 0; Set R RGEN LTSTS LFGT 025,035 H H - 4 Test F \leq 0; Set A v GEN LTSTS LFLE 141111 Н 4 Test F \leq 0; Set R RGEN LTSTS 1 LFLE 021,031 Load Field Length Register 0 FIELD VI Η Н LFLI 0 001303 BRAN Η Η Load Field Length Register 1 BRAN FIELD VI LFLI 1 001313 H H - 4 Test F < 0; Set A LTSTS v GEN LFLT 141110 н — 4 Test F < 0; Set R LFLT 020,030 RGEN LTSTS I LTSTS - H H - 4 Test F •NE• 0; Set A GEN LFNE 141112 Test F .NE. 0; Set R RGEN LTSTS - - H - 4 LFNE 022.032 н н н - Test A ≥ 0; Set A 4 GEN LTSTS SRV LGE 140414 Н 4 Test R \ge 0; Set R RGEN LTSTS I LGE 004 Н Н 4 Test A > 0; Set A LTSTS SRV GEN LGT 140415 Н 4 Test R > 0: Set R RGEN LTSTS I LGT 005 Load Halfword MRGR MOVE 1 Н LH 11 н — 4 Test H = 0; Set H LHEQ 013 RGEN LTSTS H - 4 Test H \ge 0; Set H RGEN LTSTS LHGE 004 H - 4 Test H > 0; Set H RGEN LTSTS LHGT 015 Load Halfword Left Shifted by 1 н — YN MRGR MOVE LHL1 YN MRGR MOVE H - Load Halfword Left Shifted by 2 I LHL2 Н 4 Test H ≤ 0: Set H RGEN LTSTS LHLE 011 Test H < 0: Set H __ 4 LTSTS I Н RGEN LHLT 000 Test H •NE• 0; Set H н — 4 RGEN LTSTS I LHNE H 6 5 Load I/O TLB (Prime 750 only) MCTI. VI R LIOT 000044 AP H H H - 4 Test A ≤ 0: Set A GEN LTSTS SRV LLE 140411 H - 4 Test R ≤ 0; Set R LTSTS RGEN I LLE 001 Н Test L = 0; Set A v Н LLEQ 141513 GEN LTSTS LTSTS v Н 4 Test L ≥ 0; Set A GEN LLGE 140414 H - 4 Test L > 0; Set A GEN LTSTS \mathbf{v} Н LLGT 141515 Long Left Logical Н H 4 - SHFT SHIFT SRV Н LLI. 0410XX 4 Test L ≤ 0; Set A v Η н — GEN LTSTS LLLE 141511 H - 4 Test L < 0; Set A LTSTS GEN LLLT 140410 H - 4 Test L •NE• 0; Set A v н GEN LTSTS LLNE 141512 H 4 - Long Left Rotate SHIFT SRV Н Н LLR SHFT 0412XX Long Left Shift SRV Η Η H 2 SHIFT LLS 0411XX SHFT Н н — 4 Test A < 0; Set A LTSTS SRV GEN LLT 140410 Test R < 0: Set R H - 4 RGEN LTSTS LLT 000 н н — Leave Machine Check Mode SRVI E GEN INTGY LMCM 000501 LTSTS H - 4 Test A •NE• 0; Set A GEN LNE 140412 H = 4 Test R •NE • 0; Set R RGEN LTSTS LNE 002 Load Process ID н н — — GEN MCTL VI LPID 000617 Leave Paging Mode and Jump SR F MR MCTL LPMJ 000215 Leave Paging Mode and Jump to XCS MCTL SR LPMX 000235 ΜŘ H H 7 6 Load Program Status Word AP MCTL LPSW 000711 ``` | | | 0.4007777 | | | | | | | | | | | |---|--------------|------------------|------|------------|---------------|----------|--------|-----|-----|----|-----|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | | LRL<br>LRR | 0400XX | | SHFT | SHIFT | SRV | H | | | | | - Long Right Logical | | | | 0402XX | | SHFT | SHIFT | SRV | F | | | | | 88 | | | LRS | 0401XX | | SHFT | SHIFT | SRV | Н | | | | _ | Long Right Shift | | | LT | 140417 | | GEN | LTSTS | SRV | F | I H | | | - 4 | Set A = 1 | | _ | LT | 017 | | RGEN | LTSTS | I | _ | - | · H | _ | 4 | Set R = 1 | | R | LWCS | 001710 | | GEN | MCTL | VI | - | - H | Н | 6 | 5 | Load Writable Control Store | | n | M | 42 | YY | | | I | - | - | Н | 3 | _ | Multiply Fullword | | R | MDEI | 001304 | | GEN | INTGY | VI | - | - H | H | 6 | 5 | Memory Diagnostic Enable Interleave | | R | MDII | 001305 | | GEN | INTGY | VI | - | Н | Н | 6 | 5 | Inhibit Interleaved | | R | MDIW | 001324 | | GEN | INTGY | VI | - | . Н | Н | 6 | 5 | Write Interleaved | | R | MDRS | 001306 | | GEN | INTGY | VI | _ | Н | Н | 6 | 5 | Read Syndrome Bits | | R | MDWC | 001307 | | GEN | INTGY | VI | _ | Н | Н | 6 | 5 | Load Write Control Register | | | MH | 52 | YY | | | I | _ | _ | Η | 3 | 5 | Multiply Halfword | | | MIA | 64 | NN | MRGR | | 1 | - | _ | Н | _ | - | Microcode Entrance | | | MIA | 12 01 | | MR | MCTL | v | - | Н | Н | _ | _ | Microcode Entrance | | | MIB | 74 | NN | MRGR | | I | _ | _ | Н | _ | - | Microcode Entrance | | | MIB | 13 01 | | MR | MCTL | V | _ | Н | Н | _ | _ | Microcode Entrance | | | MPL | 16 03 | | MR | INT | V | _ | Н | Н | 3 | _ | Multiply Long | | | MPY | 16 | | MR | INT | V | _ | Н | Н | 3 | - | Multiply | | | MPY | 16 | | MR | INT | SR | В | Н | Н | 3 | _ | Multiply | | _ | N | 03 | YY | | LOGIC | I | _ | _ | Η | _ | _ | AND Fullword | | R | NFYB | 001211 | | AP | PRCEX | VI | _ | Н | Η | 6 | 5 | Notify | | R | NFYE | 001210 | | AP | PRCEX | VI | _ | Н | Н | 6 | 5 | Notify | | | NH | 13 | YY | | LOGIC | I | _ | | Н | _ | | AND Halfword | | | NOP | 000001 | | GEN | MCTL | SRVI | Н | Н | Н | _ | _ | No Operation | | | NRM | 000101 | | GEN | INT | SR | Н | Н | Н | _ | _ | Normalize | | _ | 0 | 23 | YY | MRGR | | I | _ | _ | Н | _ | _ | OR Fullword | | R | OCP | 14 | | PIO | IO | SR | Н | Н | Н | _ | | Output Control Pulse | | | OH | 33 | YY | MRGR | | I | _ | _ | Н | _ | _ | OR Halfword | | _ | ORA | 03 02 | | MR | LOGIC | V | _ | Н | Н | _ | _ | Inclusive OR | | K | OTA | 74 | | PIO | IO | SR | Н | Н | Н | | - | Output from A | | | OTK | 000405 | | GEN | KEYS | SR | Н | Н | Н | 7 | 6 | Restore Keys | | | ОТК | 071 | | RGEN | KEYS | I | - | _ | Н | 7 | 6 | Restore Keys | | | PCL | 41 | NN | MRNR | , | I | | _ | Н | 6 | 5 | Procedure Call | | | PCL | 10 02 | | MR | PCTLJ | V | _ | Н | Н | .6 | 5 | Procedure Call | | | PID | 000211 | | GEN | INT | SR | В | Н | Н | | | Position for Integer Divide | | | PID | 052 | | RGEN | INT | I | _ | _ | H | | _ | Position for Integer Divide | | | PIDA<br>PIDH | 000115 | | GEN | INT | V | - | Н | Н | | _ | and the same of th | | | PIDL | 053 | | RGEN | INT | I | _ | _ | Н | | _ | Position for Integer Divide | | | | 000305 | | GEN | INT | V | _ | Н | Н | - | - | Position Long for Integer Divide | | | PIM | 000205 | | GEN | INT | SR | В | Н | | | _ | Position After Multiply | | | PIM<br>PIMA | 50 | | RGEN | INT | I | - | _ | Н | 3 | 5 | Position After Multiply | | | PIMH | 000015 | | GEN | INT | V | _ | Н | Н | 3 | 5 | Position After Multiply | | | PIML | 51 | | | INT | I | | _ | Н | 3 | 5 | Position After Multiply | | | PRTN | 000301 | | | INT | V | _ | Н | Н | 3 | 5 | Position After Multiply Long | | R | PTLB | 000611<br>000064 | | GEN | PCTLI | VI | _ | Н | | 7 | 6 | Procedure Return | | | RBQ | 141715 | | GEN | MCTL | VI | _ | _ | Н | 6 | 5 | Purge TLB (Prime 750 only) | | | RBQ | 133 | | AP<br>AP | QUEUE | V | _ | | | - | 7 | Remove From Bottom of Queue | | | RCB | 140200 | | | RGEN | I | | _ | | _ | 7 | Remove From Bottom of Queue | | R | RMC | 000021 | | GEN<br>GEN | KEYS<br>INTGY | SRVI | Н | | Н | 5 | _ | Clear C-Bit (Reset) | | | ROT | 24 | NN | | SHIFT | SRVI | E | Н | Н | _ | _ | Clear Machine Check | | | RRST | 000717 | ININ | | | I<br>VI | _ | _ | Н | - | _ | Rotate | | | RSAV | 000717 | | | MCTL | VI | _ | Н | | _ | _ | Register Restore | | | RTN | 000715 | | | MCTL<br>PCTLJ | VI<br>SR | —<br>Ц | Н | Н | _ | _ | Register Save | | | RTQ | 141714 | | | | | Н | | Н | | | Return | | | RTQ | 132 | | | QUEUE | V | _ | Н | Н | | | Remove From Top of Queue | | | s<br>S | | 1/1/ | | QUEUE | I | _ | _ | | _ | 7 | Remove From Top of Queue | | | S<br>S1A | 22<br>140110 | ΥΥ | | INT | I | | _ | Н | 2 | 1 | Subtract Fullword | | | SIA<br>S2A | 140110 | | | INT | SRV | Н | | Н | 2 | 1 | Subtract One from A | | | SAR | 140310<br>10026X | | | INT | SRV | | Н | Н | 2 | 1 | Subtract Two from A | | | SAS | 10026X<br>10126X | | | SKIP | SRV | | Н | | | | Skip on A Bit Clear | | | UNIO | 10120A | | GEN | SKIP | SRV | Н | Н | Н | _ | _ | Skip on A Bit Set | | | | | | MD | INT | v | _ | Н | Н | 2 | 1 | Subtract Long | |--------|--------------|------------------|----------|----------------|----------------|------------|--------|------------|----------|---------------|------------|--------------------------------------------------------------| | | SBL | 07 03<br>000041 | | MR<br>GEN | INT | SR | | | | | | Load Shift Count into A | | | SCA<br>SCB | 1406000 | | GEN<br>GEN | KEYS<br>INT | SRVI<br>SR | | H<br>H | H<br>H | 5<br>— | _ | Set C-Bit in Keys Enter Single Precision Mode | | | SGL<br>SGT | 100220 | | GEN | SKIP | SRV | Н | Н | Н | | - | Skip if A Greater Than Zero | | | SH<br>SHA | 32<br>15 | YY<br>NN | MRGR<br>MRGR | INT<br>SHIFT | I<br>I | _ | _ | H<br>H | 2<br>4 | 1 | Subtract Halfword Shift Arithmetic | | | SHL<br>SHL1 | 05<br>076 | NN | MRGR<br>RGEN | SHIFT<br>SHIFT | I<br>I | _ | _ | H<br>H | 4<br>4 | _ | Shift Logical<br>Shift H Left One | | | SHL2<br>SHR1 | 077<br>120 | | RGEN<br>RGEN | SHIFT<br>SHIFT | I<br>I | _ | _ | H<br>H | 4<br><b>4</b> | _ | Shift H Left Two<br>Shift H Right One | | | SHR2 | 121 | | RGEN<br>GEN | SHIFT<br>SKIP | I<br>SRV | —<br>Н | —<br>Н | H<br>H | | _ | Shift H Right Two<br>Skip | | R | SKP | 100000<br>34 | | PIO<br>RGEN | IO<br>SHIFT | SR<br>I | H | H | | _<br>4 | _ | Skip if Satisfied<br>Shift R Left One | | | SL1<br>SL2 | 072<br>073 | | RGEN | SHIFT | I | | _ | Н | 4 | _ | Shift R Left Two<br>Skip if A Less Than or Equal to Zero | | | SLE<br>SLN | 101220<br>101100 | | GEN<br>GEN | SKIP<br>SKIP | SRV<br>SRV | H<br>H | H<br>H | H<br>H | _ | _ | Skip if LSB Nonzero (A(16)=1) | | | SLZ | 100100 | | GEN<br>GEN | SKIP<br>INTGY | SRV<br>SRV | H<br>E | H<br>H | H<br>H | | _ | Skip if LSB Zero (A(16)=0)<br>Skip on Machine Check Reset | | | SMCR<br>SMCS | 100200<br>101200 | | GEN | INTGY | SRV | E | Н | Н | _ | _ | Skip on Machine Check Set<br>Skip if A Minus | | R | SMI<br>SNR | 101400<br>10024X | | GEN<br>GEN | SKIP<br>SKIP | SRV<br>SRV | H<br>H | H | H<br>H | _ | _ | Skip on Sense Switch Clear | | R | SNS<br>SNZ | 10124X<br>101040 | | GEN<br>GEN | SKIP<br>SKIP | SRV<br>SRV | H<br>H | H | H<br>H | _ | _ | Skip on Sense Switch Set<br>Skip if A Non-Zero | | R | SPL<br>SR1 | 100400<br>100020 | | GEN<br>GEN | SKIP<br>SKIP | SRV<br>SRV | H<br>H | H<br>H | H<br>H | | _ | Skip if A Plus<br>Skip if Sense Switch 1 Clear | | R | SR1<br>SR2 | 074<br>100010 | | RGEN<br>GEN | SHIFT<br>SKIP | I<br>SRV | —<br>Н | —<br>Н | H<br>H | 4 | _ | Shift R Right One<br>Skip if Sense Switch 2 Clear | | R | SR2 | 075<br>100004 | | RGEN<br>GEN | SHIFT<br>SKIP | I<br>SRV | —<br>Н | —<br>Н | H<br>H | 4 | | | | R | SR4<br>SRC | 100002<br>100001 | | GEN<br>GEN | SKIP<br>SKIP | SRV<br>SRV | H<br>H | H<br>H | H<br>H | | _ | Skip if Sense Switch 4 Clear<br>Skip if C-Bit is Clear | | R<br>R | SS1 | 101020<br>101010 | | GEN<br>GEN | SKIP<br>SKIP | SRV<br>SRV | H<br>H | H<br>H | | _ | | Skip if Sense Switch 1 Clear<br>Skip if Sense Switch 2 Clear | | R<br>R | SS3 | 101004<br>101002 | | GEN<br>GEN | SKIP<br>SKIP | SRV<br>SRV | H<br>H | H<br>H | H<br>H | | _ | Skip if Sense Switch 3 Clear<br>Skip if Sense Switch 4 Clear | | | SSC<br>SSM | 101001<br>140500 | | GEN<br>GEN | SKIP<br>INT | SRV<br>SRV | H<br>H | H<br>H | H<br>H | | | Skip if C-Bit is Set Set Sign Minus | | | SSM<br>SSP | 042<br>140100 | | RGEN<br>GEN | INT<br>INT | I<br>SRV | _<br>Н | Н | | | . –<br>- – | Set Sign Minus<br>Set Sign Plus | | R | SSP | 043<br>100036 | | RGEN<br>GEN | INT<br>SKIP | I<br>SRV | _<br>Н | — | H | _<br> _ | | - Set Sign Plus<br>- Skip if Any Sense Switch is Clear | | R | | 101036<br>21 | NI | GEN<br>N MRGI | SKIP<br>R MOVE | SRV<br>I | H | Н | Н<br>- Н | . – | | Skip if All Sense Switches are Set Store Fullword | | | STA<br>STAC | 04<br>001200 | | MR<br>AP | MOVE<br>MOVE | SRV<br>V | Н | Н<br>- Н | | | <br>- 7 | Store A Store A Conditionally | | | STAR | 54<br>166 | NI | N MRGF<br>RGEN | MOVE | Ī<br>I | | . <u> </u> | | | <br>- ; | | | | STC 0 | 176 | | RGEN<br>CHAF | CHAR | I<br>V | _ | - H | Н | ı – | - 7<br>- 7 | Store Character | | | STC 0 | 001322<br>001332 | | CHAR<br>AP | | V<br>I | _ | - H | Н | ı – | | Store Character Store Conditional Fullword | | | STCH | 137<br>136 | | AP<br>GEN | MOVE<br>PCTLJ | I<br>V | _ | _ | - H | -<br>I – | - 7 | | | | STEX | 001315<br>027 | | RGEN<br>AP | | I<br>VI | | <br>- F | - F | Ι 6 | | Stack Extend | | | STFA | 1 001330 | ът | AP | FIELD | VI | _ | | I | I - | | - Store Field Address Register<br>- Store Halfword | | | STH | 31<br>04 03 | N | MR | R MOVE<br>MOVE | v | | - H | I F | I - | | | | F | STLC<br>STLR | 001204<br>03 01 | | AP<br>MR | MOVE<br>MOVE | | | - F | | | | - Store L conditionally - Store L into Addressed Register | | • | J - MAN | | | | | | | | | | | | | R | STPM<br>STX | 000024<br>15 | | GEN<br>MR | MCTL<br>MOVE | VI<br>SRV | —<br>Н | H<br>H | | | | Store Processor Model Number Store X | |---|------------------|-------------------|----------|--------------|----------------|-------------|--------|--------|--------|--------|--------|----------------------------------------------------------------------------| | | STY<br>SUB | 35 02<br>07 | | MR<br>MR | MOVE<br>INT | V<br>SRV | _<br>Н | H<br>H | H<br>H | | _<br>1 | Store Y<br>Subtract | | | SVC<br>SZE | 000505<br>100040 | | GEN<br>GEN | PCTLJ<br>SKIP | SRVI<br>SRV | | | | _ | _ | Supervisor Call | | | TAB<br>TAK | 140314<br>001015 | | GEN<br>GEN | MOVE<br>KEYS | v<br>v | _ | H<br>H | H<br>H | | _<br>6 | Transfer A to B Move A to Keys | | | TAX<br>TAY | 140504<br>140505 | | GEN<br>GEN | MOVE<br>MOVE | v<br>v | _ | H<br>H | H<br>H | _ | _ | Transfer A to X | | | TBA<br>TC | 140604<br>046 | | GEN<br>RGEN | MOVE | V | _ | Н | Н | _ | _ | Transfer B to A | | | TCA | 140407 | | GEN | INT<br>INT | I<br>SRV | H | Н | H<br>H | 2<br>2 | 1<br>1 | Two's Complement A | | | TCH<br>TCL | 047<br>141210 | | RGEN<br>GEN | INT<br>INT | Ī<br>V | _ | — | H<br>H | 2<br>2 | 1 | Two's Complement H Two's Complement Long | | | TFLL 0 TFLL 1 | 001323<br>001333 | | GEN<br>GEN | FIELD<br>FIELD | V<br>V | _ | H<br>H | Н | | | | | | TFLR 0 | 163<br>173 | | RGEN | FIELD | I | - | _ | Н | _ | _ | Move Field Length to R | | | TKA | 001005 | | RGEN<br>GEN | FIELD<br>KEYS | I<br>V | _ | H | Н | | | Move Field Length to R<br>Move Keys to A | | | TLFL<br>TLFL | 001321<br>001331 | | GEN<br>GEN | FIELD<br>FIELD | v<br>v | _ | H<br>H | H<br>H | | _ | Transfer L to Field Length Register<br>Transfer L to Field Length Register | | | TM<br>TMH | 44<br>54 | NN<br>NN | MRNR<br>MRNR | | I | _ | _ | H<br>H | | 1<br>1 | Test Memory Fullword<br>Test Memory Halfword | | | TRFL 0<br>TRFL 1 | 165<br>175 | | RGEN<br>RGEN | FIELD<br>FIELD | I<br>I | _ | _ | H<br>H | _ | _ | Transfer R to Field Length Register<br>Transfer R to Field Length Register | | | TSTQ<br>TSTQ | 141757<br>104 | | AP<br>RGEN | QUEUE<br>QUEUE | V<br>I | _ | H | Н | | 7<br>7 | Test Queue | | | TXA<br>TYA | 141034 | | GEN | MOVE | V | _ | | Н | | | Test Queue Transfer X to A | | R | VIRY | 141124<br>000311 | | GEN<br>GEN | MOVE<br>INTGY | V<br>SRVI | G | | H<br>H | 6 | | Transfer Y to A Verify | | R | WAIT<br>WCS | 000315<br>0016XX | | AP<br>GEN | PRCEX<br>MCTL | VI<br>RVI | _ | H<br>O | Н | | _ | Wait<br>Writeable Control Store | | | X | 43 | YY | MRGR | LOGIC | I | _ | _ | Н | | _ | Exclusive OR Fullword | | | XAD<br>XBTD | 001100<br>001145 | | DECI<br>DECI | DECI<br>DECI | VI<br>VI | _ | U<br>U | H<br>H | 3 | | Decimal Add<br>Binary to Decimal Conversion | | | XCA<br>XCB | 140104<br>140204 | | GEN<br>GEN | MOVE<br>MOVE | SRV<br>SRV | H<br>H | H<br>H | H<br>H | | - | Exchange and Clear A Exchange and Clear B | | | хсм | 001102 | | DECI | DECI | VI | _ | U | Н | | 1 | Decimal Compare | | | XDTB<br>XDV | 001146<br>001107 | | DECI<br>DECI | DECI | VI<br>VI | _ | | H | _ | | Decimal to Binary Conversion Decimal Divide | | | XEC<br>XED | 01 02<br>001112 | | MR | PCTLJ | RV | F | Н | Н | - | _ | Execute | | | XH | 53 | | DECI<br>MRGR | DECI<br>LOGIC | VI<br>I | _ | - | Η | | _ | Numeric Edit<br>Exclusive OR Halfword | | | XMP<br>XMV | 001104-<br>001101 | | DECI<br>DECI | DECI<br>DECI | VI<br>VI | _ | U<br>U | H<br>H | 3 | 1 | Decimal Multiply<br>Decimal Move | | R | XVRY<br>ZCM | 001113<br>001117 | | MCTL<br>CHAR | GEN<br>CHAR | VI<br>VI | | U | Н | | 5 | Verify XIS | | | ZED | 001111 | | CHAR | CHAR | VI | | _ ; | Н | | _ | Compare Character Field<br>Character Edit | | | ZFIL<br>ZM | 001116<br>43 | NN | CHAR<br>MRNR | | VI<br>I | | | | | | Fill Character Field<br>Clear Fullword | | | ZMH | 53 | NN | MRNR | CLEAR | I | _ | _ | Н | | _ | Clear Halfword | | | ZMV<br>ZMVD | 001114<br>001115 | | CHAR<br>CHAR | | VI<br>VI | _ | U I | н<br>н | | - : | Move Character Field<br>Move Equal Length Fields | | | ZTRN | 001110 | | CHAR | | VI | | | | | | Franslate Character Fields | | | | | | | | | | | | | | | # PMA REFERENCE # Language structure ## **INTRODUCTION** The Prime Macro Assembler's language structure is both flexible and simple. For example, here is a program which includes three pseudo-operations, a machine instruction and a literal. | REL | PSEUDO-OPERATION - USE RELOCATABLE ADDRESSING | |-----------|-----------------------------------------------| | LDA = 123 | MACHINE INSTRUCTION - LITERAL | | CALL EXIT | PSEUDO-OPERATION - SUBROUTINE CALL | | END | PSEUDO-OPERATION - END OF SOURCE CODE | This section describes the structure and function of PMA language statements, and the elements, constants, symbols and expressions which comprise them. #### LINES Input to the assembler consists of instruction statements and comments (See Figure 14-1). The basic unit of information is the line (See Figure 14-2). Fields, statements and comments within a line can be delimited by either spaces, commas or colons, depending on the construction. There are three basic line formats: | Comment Line | Column 1 contains an asterisk (*). The entire line is treated as a comment. | |------------------------------|---------------------------------------------------------------------------------------------------------| | Change Page<br>Heading Lines | Column 1 contains an apostrophe ('). The rest of the line is used as a page title for subsequent pages. | | Statements | See below. | #### **STATEMENTS** # **Types** Statements may be: - Mnemonic representations of machine instructions. - Assembler pseudo-operations. - · Macro definitions and calls. #### **Syntax** Statements may have four possible fields, delimited by spaces: # [label] operation [operand] . . . [comment] **Label**: Assigns a name to a program location, such as a subroutine entry point, the address of a constant, or a storage field. The first character of a label must be in column 1 of a line. If a statement does not have a label, the first column must be blank. Labels must be legal symbols. **Operation**: Defines the action taken at assembly time (pseudo-operations, macro definitions and calls) or at execution time (machine instructions). The operation is the only field required in all types of instructions and must be entered exactly as shown in the individual statement definition. **Operand**: Contains information to be acted upon by the operation code. The number of operands and their meaning is operation-specific. Some statements do not require an operand; others require several. **Comments**: Ignored by PMA except for printing in the listing. Comments document the meaning of the operation. All text following either column 72 or two spaces after the last operand (ten spaces with macro calls) is treated as a comment. #### Elements Statement elements — labels, operation codes and operands — are composed of constants. symbols and expressions. These are a subset of the printing ASCII characters. The entire ASCII character set, printing and non-printing, may be used in comments, macro instruction operands and within literal text fields. **Constants**: Constants are explicit data values. A constant may be any of the following data types. - Decimal - Binary - Hexadecimal - Octal - Character (ASCII) - Address Constants may be used in expressions to represent bit configurations, absolute addresses, displacements and data. Section 15, Data Definition, contains a full discussion of data types and formats. **Symbols**: Symbols are alphanumeric strings which represent locations or data. They may be from 1 to 32 characters in length. The first character must be a letter (A-Z), and the remaining characters may be letters, numerals (0-9), the dollar sign (\$), or underscore (\_\_). Symbols containing more than 32 characters are allowed in the source code, but only the first 32 characters are examined by the assembler. **Expressions**: Expressions contain one or more constants or symbols, called terms, which have single precision integer values. Multiple terms are joined by operators, which may be arithmetic, relational, logical or shift. At assembly time, PMA evaluates an expression by performing the indicated operations, if any, thus producing a single precision integer result. # **Example** Comment A + 3 Arithmetic expression consisting of a variable "A" and a constant "3" A.LS.(ALPA/5) Shift expression consisting of a variable (A) and a sub-expression (ALPA/5). BETA.GE.A+\$FF Logic expression consisting of a variable (BETA) and a sub-expression (A+\$FF). You may use expressions as: - Instruction operands - Literals - Part of macro definitions and calls - Symbol-defining pseudo-operation operands Multiple statements per line: Statements may be packed two or more per line. Each statement is separated from the one following by a colon (:). The PMA assembler processes the first non-space character following the colon as the operation of a new statement. The last statement in the line is terminated by two spaces or column 73, and the rest of the line treated as a comment. If the line begins with a label, the label is assigned to the first statement on that line. Since labels must begin in column 1, there can only be one label per line, as in: LABEL1 LDA = 123:LDA = 456 COMMENT2 Multiple lines per statement: Any statement may be interrupted by a semicolon (;) and continued on the next line. The rest of the line following the semicolon is treated as a comment. Processing of the statement continues with the first non-space character in the following line. Semicolons appearing within comments are not interpreted as continuation requests. # MEMORY REFERENCE INSTRUCTION FORMAT (SRV) #### Operation Field **Mnemonic:** The operation field must include one of the memory reference instruction mnemonics. **Triple asterisk (dummy instruction):** A triple asterisk in place of an instruction mnemonic is a pseudo-operation code that causes the assembler to form a memory reference instruction with an op-code of zero. Another asterisk may be added to specify indirect addressing. The variable field of such a statement is treated like any other memory reference instruction. **Percent sign (%):** A % following the mnemonic tells the assembler to process this instruction in two word (long-reach) format. **Pound sign (#):** A # following the mnemonic tells the assembler to process this instruction in one word format. ## Operand Field The operand field of a memory reference instruction contains an address expression, which may be modified by indirection, indexing, and by case register references. **Symbolic addresses:** Addresses can be specified by any constant, symbol, literal, or expression which can be evaluated as a 16-bit number. **Indexing:** Indexing is optional and is specified by a "1", "X", or, in V or I mode, a "Y", following the address expression. The form "0" is interpreted as non-indexing. **Indirection:** An asterisk (\*) tells the assembler that this address is a pointer to another address. **Stack:** An at sign (@) used alone in the address tells the assembler that this instruction references the stack. This notation is not legal in 64V or 32I; stack base—SB%—notation is used in these modes. **Base registers (V or I mode):** A percent sign (%) following SB, LB, PB or XB tells the assembler that the operand is relative to a particular base register. **Asterisk (current location):** An asterisk (\*) in the operand field represents the current value of the assembler location counter. **Double asterisk (initial zero):** A double asterisk (\*\*) in the operand field causes the assembler to load zeroes in the 9-bit address field and sector bit. (Indexing and indirect addressing conventions are unchanged.) This convention is used when the desired location is to be developed or modified by other instructions or is not known at the time of assembly. Equals sign (literals): A literal is a constant preceded by an equals sign, as in: LDA = '100 The assembler associates the numerical value of each literal with the symbol used ('100 in this case) and reserves a storage location for a constant of the value. The value in the operand field will be the address of the literal. # **Special Cases** The assembler will generate a long instruction if any of the following cases apply: - 1. Indexing by Y is specified. - 2. A percent (%) opcode modifier is used. - 3. The opcode does not have a short form (zero opcode extension). - 4. If the mode of the address is external of common (SEG/SEGR mode only). - 5. The address is linkage relative and not in the range '400 to '777. - 6. The address is stack relative and not in the range '10 to '377. - 7. The address is temporary base relative. - 8. Indirection is specified and a # opcode modifier is not used (SEG or SEGR mode only). If any of the cases apply and a # opcode suffix was used, an error will be generated. In SEG or SEGR mode, if the expression mode is absolute, it must be in the range 0 to 7 to specify a compatible register address. If a long instruction is generated, an error will be reported since register set addressing is only available with short instructions. Because of rule 8 above, an instruction that specified indirection through a register must also have a # opcode suffix. #### **INSTRUCTION FORMATS - I-MODE** The assmbler formats for I-Mode instructions are listed in Table 14–1. See Section 9, Data Structures, for the I-Mode machine formats. | Table | 14-1. | Assembler | Formats | [I-Mode] | |-------|-------|-----------|---------|----------| | | | | | | | | | | | | | Instruction Type | Assembler | |------------------|-------------------------------------------------------| | MRGR | op r,addr | | MRFR | op f,addr | | MRNR | op addr | | | | | IBRN | $\operatorname{op}\left\langle h\right\rangle$ , word | | | \ <del>-</del> | | * IBRN bit test | op r,bitno, word | | RGEN | on r | **GEN** op AP op ap \*\* RGEN field register op falr,r \*\* BRAN field register op falr data \*\* AP field register op falr,ap # Abbreviations | WORD | word number address field, no indirection or indexing | |--------|---------------------------------------------------------------| | ADDR | full segmented address field, optional indirection/indexing b | | | general registers 1–7 | | AP | argument pointer, optional indirection | | BIT | bit number (1–32) | | DATA | 16 bit data word | | FALR | field register number (0-1) | | F | floating register number (0-1) | | OPCODE | instruction operation code | | R | general register number (0–7) | 1 March, 1979 14-7 FDR 3059 <sup>\*</sup> bitno selects a specific opcode \*\* FALR selects a specific opcode ``` (0001) ***** I-MODE ADDRESSING ILLUSTRATION ****** (0002) * (0003) * SEGR (ØØØ4) 4 000004 (ØØØ5) IX EQU (0005) * (0007) STRT L l,DATA DIRECT 000000: 002240.000032 000002: 002540.000030 2,PTR,* INDIRECT (ØØØ8) 3,PTR,7 INDEXED 000004: 002674.000030 (0009) L 4,PTR,*7 POST-INDEXED, INDIRECT 000006: 003174.000030 (0010) ۲. (0011) L 5,PTR,7* PRE-INDEXED, INDIRECT ØØØØ1Ø: ØØ3334.ØØØØ3Ø 6,PTR,*(IX) POST-INDEXED, INDIRECT 000012: 003560.000030 (0012) L 7, PTR, (IX+2) * PRE-INDEXED, INDIRECT (0013) T. 000014: 003730.000030 (0014) * 1,='100L GENERAL REGISTER IMMEDIATE 000016: 002205.000100A (0015) L ØØØØ2Ø: ØØ3Ø42.ØØØ4ØØL (ØØ16) 4,='1234567L GENERAL REGISTER LITERAL L ØØØØ22: Ø14ØØ2.Ø4Ø2Ø1A (ØØ17) FL \emptyset,=1.\emptyset FLOATING REGISTER IMMEDIATE Ø,=3.14159 FLOATING REGISTER LITERAL FL 000024: 014042.000402L (0018) (0019) * REGISTER TO REGISTER 002214 (0020) 1.3 000026: DFL 0,1 FLOATING REGISTER TO REGISTER Ø14216 (ØØ21) 000027: (ØØ22) (0023) * (ØØ24) PTR BSS 2 000030: 000032: (ØØ25) DATA BSS 2 (0026) * (0027) * 000034 (ØØ28) END ``` #### HOW TO WRITE V OR I MODE CODE IN PMA In order to take advantage of the PMA facilities, the structure of a V or I Mode program should reflect the system architecture design for the separation of code and data (see Reference Guide, System Architecture). The recommended structure is: #### Prologue | SEG/SEGR | Sets up segmented address space | |----------|--------------------------------------------------| | RLIT | Puts literals in the procedure area | | ENT | Entry point declarations | | | Code | | | Executable code | | | Data Area | | DYNM | Stack variable declarations | | LINK | defines linkage area containing static variables | | ECB | entry control block | | | End | References ECB name. PMA makes using the segmented architecture easy. Thus the programmer can write straightforward code, such as LDA ADDR. The assembler, depending on the definition of ADDR, may generate a one word or two word instruction, and may reference either the stack area, the linkage area, the procedure area or a temporary area. This is possible because symbols carry a great deal of state information with them. # **Key Points** **ECB:** The ECB (entry control block) describes the environment the program runs in. It includes the location to start execution, the name of the first argument, if any, and the number of arguments. The ECB is the link used by the system to run the module. It may be located anywhere, but normally it goes in the linkage data area in order to produce pure code. **Stack:** The default stack size includes a stack frame header. Additionally, all the stack variables defined by the DYNM pseudo-operation are added to the stack frame size and the size is automatically put into the ECB definition. Stack variables are defined sequentially and may be any size. For example DYNM STAR(1) generates one word, while argument pointers, which are three word indirect pointers to the first word of an argument, would be defined as, for example, DYNM STPTR(3). Definition of stack variables by DYNM allows the assembler to build the appropriate addressing forms automatically e.g. DYNM STAR(1); LDA STAR will cause the assembler to generate the address form explicitly shown by LDA# SB%+STAR. **Code:** The assembler automatically places code in the procedure segment; the PROC pseudo-operation is not necessary unless you want to put some code after the LINK pseudo-operation which defines the linkage area. #### Note Since the assembler picks the instruction length for you, be careful about using skips and compares—they assume a one word instruction following them. Also, be aware that, by default, all pointers are long. **Linkage area:** The LINK pseudo-operation tells the assembler to tag the variables which are defined after it (using BSS, ECB, DATA, etc.) as linkage base relative. These are the static, impure data and variables required for pure procedures. Literals: The RLIT pseudo-operation will cause literals to be generated in the procedure area. #### **Examples** The series of annotated examples beginning on page 14-10 below show a subroutine as a programmer might write it in V-Mode, I-Mode, and R-Mode. Argument transfer and referencing are also shown in Section 8—Interfacing with System Libraries. ADDARY, jrw, 01/11/79 -321 MODE- ``` ADDARY, jrw, 01/11/79 -32I MODE- (0001) * (0002) * Add the elements of a 10 dimensional array of 16-bit values, producing (0003) * a 16-bit result and returning a count of the number of members of the (0004) * array which were zero. The result is printed on the user terminal. (0005) * (ØØØ6) * (0007) (0008) Calling sequence (Fortran): (0009) (0010) INTEGER ARY(10), NZERO, ADDARY, RESULT (0011) (ØØ12) RESULT = ADDARY (ARY, NZERO) (0013) (0014) (0015) (ØØ16) Calling sequence (PMA): (0017) (0018) CALL ADDARY ARRAY WHOSE ELEMENTS ARE TO BE SUMMED (0019) AΡ ARY.S RETURNED # ELEMENTS = Ø AΡ NZERO.SL (0020) RESULT RETURNED IN (A) (GR2H) (ØØ21) (0022) (ØØ23) (0024) ADDARY, ADDECB ENTRY DECLARATION ENT 999499 (0025) (0026) 321-MODE SEGMENTED ADDRESSING SEGR (0027) PLACE LITERALS IN PROCEDURE FRAME (0028) RLIT (0029) (0030) * ECB CAUSES CONTROL TO BE PASSED HERE ON CALL aaaaaa (0031) ADDARY EQU TRANSFER POINTERS TO ARGUMENTS ARGT (ØØ32) 000000: 000605 (0033) 1,=-10 # ELEMENTS TO ADD INITIALIZE # ELEMENTS WHICH = Ø 000001: 022201.177766A (0034) 000003: 134741.000015S 000005: 022601.000000A ZMH NZERO,* (0035) 3,=Ø INITIALIZE ACCUMULATOR (0036) (0037) (0038) *---LOOP TO PERFORM ACTUAL ADDITION: (0039) ADDLP EQU 000007 PICK UP NEXT ARRAY ELEMENT 2, ARY, * 000007: 022541.000012S (0040) T.H TEST ZERO 2,LP10 BHNE 000011: 020513.000015 (0041) VALUE IS ZERO, BUMP COUNTER NZERO.* 000013: 134141.000015S (0042) TMH COMPUTE NEW SUM (RESULT => GR3H) UPDATE WORD# OF POINTER TO NEXT ARRAY ELEMENT 024610 (ØØ43) LP1Ø AΗ 3,2 000015: ARY+1 000016: 134041.0000138 IMH (0044) BRANCH IF NOT DONE, PROCESS NEXT ELEMENT 1,ADDLP 000020: 020340.000007 (0045) BHIl (0046) (0047) *---PRINT RESULT ON USER TERMINAL.. SO WE CAN PRINT SUM 000022: 062641.000020S STH 3,SUM (0048) CALL TNOUA 000024: 114342.000420L (0049) =C'RESULT IS ',S AΡ 000026: 000100.000043 (0050) ΑP =10,SL 000030: 000300.000050 (0051) PRINT DECIMAL RESULT ØØØØ32: 114342.ØØØ422L CALL TODEC (0052) ΑP SUM,SL 000034: 000700.000020S (0053) PRINT NEW-LINE CALL TONL ØØØØ36: 114342.ØØØ424L (ØØ54) (0055) * *---THRU HERE WHEN DONE - RETURN WITH SUM IN THE GR2H (A-REGISTER). (0056) 000040: 022441.000020S (0057) LH 2,SUM BACK TO CALLER 000611 (0058) PRTN 000042: (0059) * (0060) * (0061) *---DATA DEFINITION: (0062) * ARY (3), NZERO (3), SUM DYNM 000012 (0063) 000015 000020 ``` ``` (0064) * (0065) * (ØØ66) (ØØ67) * LINK 000400> 000000 (0068) ADDECB ECB ADDARY,, ARY, 2 000022 000012 000002 177400 010000 (0069) * (0070) * (0071) * 000420 (ØØ72) END 000043: 000044: 00.151305A 00.151725A 00.146324A 00.120311A 00.151640A 000045: 000046: 000047: 000050: 00.000012A 000420> 000000.000000E 000422> 000000.000000E 000424> 000000.000000E PROC 000051 LINK 000026 TEXT SIZE: STACK ØØØØ21 ADDARY 000000 0031 0068 000400L 0068 000007 0039 ADDECB ADDLP ØØ45 ARY 000012S 0040 0044 0063 0068 LP10 000015 0041 0043 000015S 0035 NZERO 0042 0063 SUM 000020S 0048 0053 0057 0063 TNOUA 000000E 0049 TODEC TONL 000000E 0052 000000E 0054 0000 ERRORS (PMA-REV 16.2) {\tt BOTTOM} ``` 1 March, 1979 qu ADDARY, jrw, 01/11/79 -64R MODE- ``` ADDARY, jrw, Ø1/11/79 -64R MODE- (0001) * (0002) * Add the elements of a 10 dimensional array of 16-bit values, producing a 16-bit result and returning a count of the number of members of the array which were zero. The result is printed on the user terminal. (0003) * (0004) (0005) (0006) (0007) (0008) (0009) Calling sequence (Fortran): (0010) INTEGER ARY (10), NZERO, ADDARY, RESULT (0011) (0012) RESULT = ADDARY (ARY, NZERO) (ØØ13) (0014) (0015) Calling sequence (PMA): (0016) (0017) CALL ADDARY (0018) ARRAY WHOSE ELEMENTS ARE TO BE SUMMED DAC ARY (0019) RETURNED # ELEMENTS = Ø DAC NZERO (ØØ2Ø) (TO TERMINATE ARG LIST) DEC (0021) RESULT RESULT RETURNED IN (A) STA (ØØ22) (0023) (0024) (0025) ENTRY DECLARATION 000000 (0026) ENT ADDARY (0027) CHECK 64R MODE ADDRESSING VIOLATIONS (0028) C64R RELATIVE MODE ASSEMBLY (0029) REL (0030) (0031) * RETURN ADDRESS SAVED HERE BY 'JST' INSTRUCTION (0032) ADDARY DAC 000000: 00.000000A TRANSFER ARGUMENTS' ADDRESSES 000001: 10.000000E (0033) CALL FSAT (2 ARGUMENTS) (ØØ34) DATA 000002: 000002 PTR TO ARRAY 00.000000A (ØØ35) ARY DAC 000003: PTR TO COUNTER FOR ELEMENTS W/ VALUE = 0 00.000000A (ØØ36) NZERO DAC 000004: (0037) * =-10 # ELEMENTS TO ADD T.DX 000005: 35.000033 (0038) INITIALIZE COUNTERS CRA 000006: 140040 (0039) SUM 000007: 04.000032 (0040) STA NZERO,* # ELEMENTS WHICH = Ø STA 000010: 44.000004 (0041) (0042) *---LOOP TO PERFORM ACTUAL ADDITION: (0043) EQU (0044) ADDLP 000011 PICK UP NEXT ARRAY ELEMENT ARY,* 000011: 42.000003 (0045) LDA TEST ZERO (ØØ46) SNZ 101040 000012: VALUE IS ZERO, BUMP COUNTER (0047) IRS NZERO,* 52.000004 000013: COMPUTE NEW SUM 06.000032 SUM (0048) ADD 000014: STA SUM (0049) 000015: 04.000032 BUMP POINTER TO NEXT ARRAY ELEMENT (0050) IRS 12.000003 000016: TEST DONE IRX 140114 (0051) 000017: NOT DONE, PROCESS NEXT ELEMENT ADDLP (0052) JMP 000020: 01.000011 (0053) * (0054) *---PRINT RESULT ON USER TERMINAL... TNOUA CALL 000021: 10.000000E (ØØ55) =C'RESULT IS ' TEXT TO BE PRINTED DAC 000022: 00.000034 (0056) # CHARACTERS =10 000023: 00.000041 (0057) DAC ø DEC 000024: 000000 (0058) PRINT DECIMAL RESULT TODEC CALL 10.000000E (0059) 000025: DAC SUM 00.000032 (0060) 000026: PRINT NEW-LINE TONL CALL 10.000000E (0061) 000027: (0062) *---THRU HERE WHEN DONE - RETURN WITH SUM IN THE A-REGISTER. (0063) 02.000032 LDA SUM (0064) 000030: ADDARY,* BACK TO CALLER JMP (0065) 41.0000000 000031: (0066) (ØØ67) (0068) *---DATA DECLARATION: (0069) TEMPORARY SUM (0070) SUM BSS 1 000032: (0071) (0072) (0073) 000033 (0074) END 00.177766A 000033: 000034: ØØ.1513Ø5A 000035: ØØ.151725A ``` ``` 000036: 000037: ØØ.146324A ØØ.12Ø311A ØØ.15164ØA 000040: 00.000012A 000041: TEXT SIZE: 000042 WORDS ^214^014 ADDARY 000000 0032 ( ADDLP 000011 0044 ( 000000 0032 0065 000011 0044 0052 000003 0035 0045 000000E 0033 000004 0036 0041 000032 0040 0048 000000E 0055 000000E 0059 0050 ARY F$AT NZERO 0047 0049 0060 0064 0070 SUM 0048 TNOUA TODEC TONL 000000E 0061 0000 ERRORS (PMA-REV 16.2) BOTTOM ``` FDR 3059 14-13 1 March, 1979 ADDARY, jrw, 01/11/79 -64V MODE- ``` (0001) * ADDARY, jrw, 01/11/79 -64V MODE- (0002) * Add the elements of a 10 dimensional array of 16-bit values, producing a 16-bit result and returning a count of the number of members of the array which were zero. The result is printed on the user terminal. (0003) * (0004) * (0005) (0006) (0007) (0008) (0009) Calling sequence (Fortran): (0010) (0011) INTEGER ARY(10), NZERO, ADDARY, RESULT (0012) RESULT = ADDARY (ARY, NZERO) (ØØ13) (0014) (0015) (0016) Calling sequence (PMA): (ØØ17) (ØØ18) CALL. ADDARY (0019) ARY,S ARRAY WHOSE ELEMENTS ARE TO BE SUMMED AΡ (0020) ΑP NZERO.SI. RETURNED # ELEMENTS = Ø (0021) RESULT RETURNED IN (A) (GR2H) (0022) (0023) (ØØ24) 000400 (0025) ENT ADDARY, ADDECB ENTRY DECLARATION (0026) (0027) SEG 64V-MODE SEGMENTED ADDRESSING (0028) PLACE LITERALS IN PROCEDURE FRAME (0029) (0030) * 000000 (0031) ADDARY EQU ECB CAUSES CONTROL TO BE PASSED HERE ON CALL 000000: 000605 (ØØ32) ARGT TRANSFER POINTERS TO ARGUMENTS (0033) # ELEMENTS TO ADD INITIALIZE COUNTERS 000001: 35.000037 (0034) LDX =-10 000002: 140040 (0035) CRA 04.000020S 000003: (0036) STA SIIM 000004: 051421.000015S NZERO,* # ELEMENTS WHICH = Ø (0037) STA (0038) (0039) *---LOOP TO PERFORM ACTUAL ADDITION: 000006 (0040) ADDLP EOU 000006: 045421.0000125 (0041) ARY.* PICK UP NEXT ARRAY ELEMENT LDA 000010: 140613.000014 (0042) BNE LP10 TEST ZERO 000012: 065421.000015S VALUE IS ZERO, BUMP COUNTER (0043) NZERO,* IRS 06.000020S 000014: (ØØ44) LP1Ø ADD SUM COMPUTE NEW SUM 000015: 04.000020S (0045) STA SUM 000016: 12.0000135 (0046) ARY+1 UPDATE WORD# OF POINTER TO NEXT ARRAY ELEMENT IRS 000017: 141334.000006 (0047) ADDLP BRANCH IF NOT DONE, PROCESS NEXT ELEMENT (0048) (0049) *---PRINT RESULT ON USER TERMINAL... 000021: 061432.000420L (0050) CALL TNOUA 000023: 000100.000040 (0051) AΡ =C'RESULT IS ',S 000025: 000300.000045 (0052) AΡ =10,SL ØØØØ27: Ø61432.ØØØ422L (0053) CALL TODEC PRINT DECIMAL RESULT 000031: 000700.000020S 000033: 061432.000424L (0054) ΔP SUM,SL CALL (0055) TONL PRINT NEW-LINE (0056) * (0057) *- --THRU HERE WHEN DONE - RETURN WITH SUM IN THE A-REGISTER. 000035: 02.000020S (0058) LDA SUM 000036: 000611 (0059) PRTN BACK TO CALLER (0060) * (0061) * (0062) *---DATA DEFINITION: (0063) * 000012 DYNM (0064) ARY(3),NZERO(3),SUM 000015 000020 (0065) * (0066) * (0067) LINK (0068) * 000400> 000000 (ØØ69) ADDECB ECB ADDARY,, ARY, 2 000022 000012 000002 177400 014000 ``` ``` (0070) * (0071) * (0072) * 000420 (0073) END 000037: ØØ.177766A 00.151305A 00.151725A 00.146324A 00.120311A 000040: 000041: 000042: 000043: ØØ.15164ØA 000044: 00.000012A 000045: 000420> 000000.000000E 000422> 000000.000000E 000424> 000000.000000E TEXT SIZE: PROC 000046 LINK ØØØØ26 STACK 000021 ADDARY 000000 0031 0069 000400L 0069 ADDECB 000400L 0069 000006 0040 000012S 0041 000015S 0037 000020S 0036 000000E 0053 000000E 0053 0047 ADDLP ARY LP10 0046 0044 0043 0064 0069 0064 NZERO 0045 0054 0058 0064 SUM 0044 TNOUA TODEC TONL 0000 ERRORS (PMA-REV 16.2) ``` BOTTOM 14-15 1 March, 1979 FDR 3059 # Data definition This section discusses all aspects of the definition and usage of data constants within a program. #### **CONSTANTS** Constants are divided into two major categories: numeric and character. They may be explicitly defined by pseudo-operations, such as OCT and DEC, or implicitly defined by usage within expressions and literals. Constants are used in expressions, literals. and DATA statements. In expressions, each constant must be one 16-bit word. See Data Defining Pseudo-Operations for a full discussion of all data type pseudo-operations referenced in this section. The format of a constant determines how PMA will process it. Table 15-1 shows the data types and formats of all legal numeric constants. Normally, you would use DATA or DEC to define stand-alone constants, and the form defined by data type symbol to express constants in an expression or literal. #### Integer constants All integer constants are signed whole-number quantities and may be single or double precision. Single precision is the default: double precision is expressed by appending the letter L to the constant. The sign, if present, follows the data type symbol. | Precision | Address Mode | | Range | |-----------|--------------|-------|-----------------------------| | Single | SRVI | From: | $-32.768 \ (-2^{**}15)$ | | | | To: | +32,767 (2**15-1) | | Double | SR | From: | $-1.073,741.824 \ (-2**30)$ | | | | To: | +1,073,741.823 (2**30-1) | | Double | VI | From: | -2,147,483,648 [ $-2**31$ ] | | | | To: | +2,147,483,647 (2**30-1) | **Decimal**: Whole number. base 10 quantities Data Type Symbol: none | Precision | Constant | Listing Representation | |------------------|-----------|------------------------| | Single Precision | DATA 123 | 000173 | | | DEC 123 | 000173 | | | 123 | 000173 | | Double Precision | DATA 123L | 000000 000173 | | | DEC 123L | 000000 000173 | | | 123L | 000000 000173 | | Tab | Table 15-1. Numeric Constants | | | | | | | | | | | |--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------|-----------------|------------------------|------------------------------|------------------|-----------------------------|-----------------------------------------|-------------------------|-----------------------|-----------------------------------------| | Class | s Source | Symbo | l Pseudo-<br>Op | Binary<br>Scale | Notes | Exponent | Notes | Precision | Symbol | Expression | Example | | I | D | | DEC | Scare | 1 | | | Single<br>Double | | YES<br>NO | 123<br>1234L | | Statutistic valous copic vers | 0 | ,<br>O , | OCT<br>OCT | _ | _ | | _ | Single<br>Double | | YES<br>NO | `123<br>'1234L | | Martin Committee | H | \$<br>X' | HEX<br>HEX | | | | _ ` | Single<br>Double | $\frac{\frac{1}{L}}{L}$ | YES<br>NO | \$1A8<br>\$1A8L | | Berthold Control of Control | В | %<br>B' ' | | | <u>-</u> | | <u>-</u> | Single<br>Double | | | <del></del> | | FX | Ď | | DEC | B<br>BB<br>BBB<br>BBBB | Req.<br>Req.<br>Req.<br>Req. | E<br>E<br>E<br>E | Opt.<br>Opt.<br>Opt.<br>Opt | Single<br>Double<br>Triple<br>Quadruple | | YES<br>NO<br>NO<br>NO | 12.5B2<br>12.5BB<br>12.5BBB<br>12.5BBBB | | FP | D | _ | | _ | 4 | E<br>D | Opt.<br>Req. | Single<br>Double | _ | NO<br>NO | 1.23E-2<br>1.23D-6 | | | B Binary D Decimal FP Floating point FX Fixed Point O Octal Decimal integers have no decimal point, binary scaling or exponent. Generates 32-bit long integers without holes. Octal digits should leave hole in high order bit of second word if in non SEG mode. Must be absent. | | | | | | | | | | | Octal: Whole number, base 8 quantities Data Type Symbol: Apostrophe ('), letter O plus single quotes (O' '). | Precision | Constant | Listing Representation | |------------------|-------------|------------------------| | Single Precision | DATA '123 | 000123 | | - | DATA O'123' | 000123 | | | OCT 123 | 000123 | | | `123 | 000123 | | | O'123' | 000123 | | Double Precision | DATA '123L | 000000 000123 | | | OCT 123L | 000000 000123 | | | '123L | 000000 000123 | Hexadecimal: Whole number, base 16 quantities. The hexadecimal digit values are: | Hexadecimal | Decimal | |-------------|---------| | 0 - 9 | 0 - 9 | | A | 10 | | В | 11 | | C | 12 | | D | 13 | | E | 14 | | F | 15 | Data Type Symbol: Dollar Sign (\$), letter X plus single quotes (' '). | Precision | Constant | Listing Representation | |------------------|--------------|------------------------| | Single Precision | DATA \$30BF' | 030277 | | | DATA X'30BF | 030277 | | | HEX 30BF | 030277 | | | X'30BF | 030277 | | Double Precision | DATA \$30BFL | 000000 030277 | | | HEX 30BFL | 000000 030277 | | | \$30BFL | 000000 030277 | The hexadecimal and octal are bit representations, not base conversions, so if you wish to represent a 31-bit number (bit 17=0) you must explicitly specify the zero. Binary: Whole number, base 2 quantities Unlike the other integer data types (decimal, octal and hexadecimal), there are no special binary pseudo-operations. The general data defining pseudo-operation, DATA, may be used with the binary designator to define binary strings. Data Type Symbol: Percent Sign (%), letter B plus single quotes (B' '). | Precision | | Constant | Listing Representation | |------------------|------|--------------|------------------------| | Single Precision | DATA | %11100101 | 000345 | | | DATA | B'11100101' | 000345 | | | | % '11100101' | 000345 | | | | B'11100101' | 000345 | | Double Precision | DATA | %11100101L | 000000 000345 | # Fixed point decimal constants Fixed point decimal constants must have an explicit binary point, expressed as a binary scale factor (see discussion below). These constants may include a decimal point and/or an exponent (see discussion below). The precision may be single, double, triple or quadruple and is indicated by the number of Bs in the binary scale factor, e.g., B=single BB=double BBB=triple BBBB=quadruple **Binary scaling**: Binary scaling, which is valid only for fixed point decimal constants, determines where the binary point will be. The figure below shows the single precision binary point positions. Bit 1 is the sign bit. 123B6 gives an assembly error because there is not enough room to the left of the binary point to contain the whole number representation of 123. This is true for all addressing modes—see Assembly Control Pseudo-Operations—and all precisions. Negative scaling is, however, permitted. | Constant | Listing Representation | | | | | | | | Pat | | | | | | | | | |----------|------------------------|---|---|---|---|---|---|---|-----|---|---|---|---|---|---|---|----| | 123B18 | 000017 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 1 | 1 | 1 | 1 | | 120210 | | | | | | | | | | | | | | | | | 16 | The binary digits that extend to the right of the word are truncated without error. If this were double precision, these bits would continue into the second word. Normally, you will probably use B15 for single precision fixed point numbers. | Constant | Listing Representation | | | | | | | | Bit | Pat | teri | n | | | | | | | |----------|------------------------|---|---|---|---|---|---|---|-----|-----|------|----|----|----|----|----|----|----| | 123.5B7 | 075600 | 0 | 1 | 1 | T | 1 | 1 | 0 | 1 | 1 | 1 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | | | 1 | 2 | 3 | | 4 | 5 | 6 | 7 | 8 | 9 | 10 | 11 | 12 | 13 | 14 | 15 | 16 | | | | | | | | | | | | В | 7 | | | | | | | | Note the handling of the fractional portion of the number relative to the binary point. **Precision**: As stated above, there are four levels of precision for fixed point decimal numbers: B=single—one 16-bit word BB=double—two 16-bit words BBB=triple—three 16-bit words BBBB=quadruple—four 16-bit words The format varies between SEG and non-SEG modes — see Assembly Control Pseudo-operations. In SEG mode, the sign bit (bit 1) of each subsequent word following the first is included in the binary count. Thus, in the truncation example above, bits 1 and 2=0, 3 and 4=1. In non-SEG modes, the sign bit of all subsequent words is always 0, and binary point counting continues from bit 2 of each word. The truncation example would have bit 1=0 and bits 2 and 3=1 and 4=0. To generalize—PMA converts a constant entered as $K_{10}$ $B_n$ to $K_2$ (2\*\*-n), where $K_{10}$ is the decimal constant, $K_2$ is the same constant expressed in binary, and n is the number following the letter "B", "BB", "BBB", or "BBBB". **Powers of 10 (E)**: If an E code is present, it must precede the required B code. The decimal value of the constant is multiplied by the power of 10, specified by the integer following the E, before it is converted to binary. The exponent may be positive or negative. Again, be careful to ensure that there is enough room to the left of the binary point to hold all the digits. If not, an error will occur. #### SEG examples: Single Precision | | Precision | Constant | Listing Representation | |-------|------------------|-----------|------------------------| | | Double Precision | 123E1BB17 | 000463 100000 | | | Single Precision | 123E0B15 | 000173 | | | 0 | 123E1B15 | 002316 | | Non-S | EG examples: | | | | | Precision | Constant | Listing Representation | | | Double Precision | 123E1BB17 | 000463 040000 | 123E0B15 123E1B15 000173 002316 #### Floating point decimal constants Binary Scaling must not be used in floating point constants. Single precision floating point: Single-precision floating point quantities are expressed by a decimal fraction, with or without a decimal exponent (Emm). | Constant | Listing Representation | |----------|------------------------| | 1.28E2 | 040000 000210 | | 1.28 | 050753 102601 | | -11.28 | 122702 107604 | | 1.28E-14 | 071512 145122 | The assembler converts the specified values to an 8 bit binary exponent and a 23 bit binary fraction in two successive words, as shown in Figure 15-1. The exponent is represented in excess-128 notation, and can range from $2^{**}$ -127 to $2^{**}$ +127 (roughly $10^{**}$ -38 to $10^{**}$ +38). An error message is generated if the exponent exceeds this range. The assembler automatically generates a normalized fraction of the largest possible value less than 1. Numbers specified in this format have significant decimal digits. Negative numbers are formed by generating a positive number of the specified magnitude and then forming the two's complement of both data words, excluding the exponent. The number zero is assembled as two consecutive all-zero data words. Double precision floating point: Double precision floating point quantities are expressed by a decimal integer or fraction with a decimal exponent (Dmm). The assembler converts the specified value to a 16-bit binary exponent and 47-bit binary fraction, in four successive words, as shown in Figure 15-1. The exponent is represented in the same excess-128 notation as single-precision floating point. The assembler automatically generates a normalized fraction of the largest possible value less than 1. Negative numbers are formed by generating a positive number of the specified magnitude and then taking the two's complement of all three fraction words, excluding the exponent. The number zero is assembled as consecutive all-zero data words. #### Character (ASCII) constants ASCII character strings are specified by the letter C followed by the string enclosed in apostrophes, and are packed two per 16-bit word. Colons (:) and semicolons (;) may be encoded by preceding them with the PMA escape character (an exclamation point). | Constant | Listing Representation | |----------|------------------------| | C'AB' | 140702 | | C'A' | 140640 | Single characters defined by C" are left-justified with the right half of the word filled with a blank (ASCII representation '240). Single characters defined by R" are right-justified with the left half of the word filled with zeros. | Constant | Listing Representation | |----------|------------------------| | C, Y, | 140640 | | R'A' | 000301 | #### **TERMS** A term is the smallest element of PMA which represents a separate and distinct value. It has a single precision integer value (fits in a 16-bit word) and may be a constant or a symbol. Terms may be used alone or in combination with other terms to form expressions. **MANTISSA** 2 16 **MANTISSA EXPONENT (EXCESS 128)** 17 24 25 32 A. Single Precision Floating Point **MANTISSA** 2 16 **MANTISSA** 17 32 **MANTISSA** 33 48 **EXPONENT (EXCESS 128)** 49 64 **B.** Double Precision Floating Point Figure 15-1. Floating Point Data Formats Every term, whether used alone or in an expression, has both a value and a mode which are either defined by the assembler or inherent in the term itself. Symbols defined by the EQU, SET, and XSET pseudo-operations receive both the mode and the value of the term or evaluated expression; labels take the current mode and value of the program counter (see Origin Control pseudo-operations for a discussion of how the mode of the program counter is set). Examples include: | '123 | Octal constant. | |--------|---------------------------------------------------------------------------------------------------| | C'A' | ASCII constant. | | ALPHA | Symbol. | | 1.23E2 | Invalid because it is a floating point number; it does not have a single precision integer value. | | C'ABC' | Invalid because the value is too large for a 16-bit word. | #### Value The value of a term is the numeric representation which is assembled into the object code. It can be a location or data. | Symbol | Usage | Explanation | |--------|-----------------|----------------------------------------------------------------------------------------------------------------| | LABSYM | LABSYM LDA LOC | LABSYM is a label symbol whose value is a location (program counter value) of the instruction LDA LOC. | | DATSYM | DATSYM DATA '10 | DATSYM is a label symbol whose value is<br>the location (program counter value) of the<br>constant '10. | | ADSYM | ADSYM DAC LOC | ADSYM is a label symbol whose value is<br>the location (program counter value) of the<br>address constant LOC. | | ABSSYM | ABSSYM EQU '10 | ABSSYM is a symbol whose value is '10. | | CHRSYM | CHRSYM EQU C'A' | CHRSYM is a symbol whose octal value is 140640. | #### Mode The mode defines whether the value associated with a symbol is absolute or relative. Table 15-2 summarizes the use of the modes defined below. **Absolute**: The value of the symbol does not change upon program relocation. Symbols equated to constants and the results of expression operations other than addition and subtraction have a mode of absolute. **Stack relative**: The symbol is defined relative to the start of the stack area. Variables defined by the DYNM pseudo-operation or by a + value (non-segmented addressing modes) or by SB%+value (segmented addressing modes) have a mode of stack relative. **External**: The symbol is defined in a separately assembled module and is identified by an EXT pseudo-operation. **Procedure absolute (SEG or SEGR only)**: The symbol is defined relative to the start of the procedure segment and is identified by PB%+value. **Linkage base relative (SEG or SEGR only)**: The symbol is defined relative to the start of the link frame and is identified by LB%+value, or \* if the origin is LINK frame. Temporary base relative (SEG or SEGR only): The symbol is defined relative to the contents of the temporary base register and is identified by XB%+value. Relative (Procedure relative (SEG or SEGR): The symbol is defined relative to the start of the module. **Common**: The symbol is defined relative to a common data area which has been defined by a COMM pseudo-operation. This common data area may be shared by several independently assembled routines. | | Generated<br>By | Symbol | Usage | Value | Listing<br>Representation | |---------------------------------------------------|----------------------------------------|-----------|--------------------|----------------|---------------------------| | Absolute | Labels <sup>1</sup><br>Constants<br>** | ABSSYM | ABSSYM EQU '123 | `123 | 000123A | | | Expression<br>Operations | EXPSYM | EXPSYM EQU '3+'4 | 7 | 000007A | | Relative (non-SEG)<br>Procedure (SEG)<br>Relative | Labels | LABSYM | LABSYM LDA LOC | Current PC | Current PC | | Common | COMM Pseudo-<br>Operation | В | COMM A. B. C(3), D | <b>1</b> 2 | 000001C | | Stack Relative | DYNM Pseudo-<br>Operation | | DYNM ('3) | `3 | 000003S | | | @[Non-SEG mode] | SKSYM2 | SKSYM2 EQU @+'6 | `6 | 000006S | | | SB% (SEC modes) | SKSYM3 | SKSYM3 EQU SB%+'7 | <sup>1</sup> 7 | 000007S | | External | EXT Pseudo-<br>Operation | EXTSYM | EXT EXTSYM | 0 | 000000E | | Procedure<br>Absolute | PB% | PBSYM | PBSYM EQU PB%+'2 | `2 | 000002P | | Linkage Base | LB% | LBSYM | LBSYM EQU LB%;+'5 | 5 | 000005L | | Relative | LINK | LBSYML | LINK | | | | | | | LBSYM DAC 5 | <sup>7</sup> 5 | 000005L | | Temporary Base<br>Relative | XB% | XBSYM | XBSYM EQU XB%+3 | <b>'3</b> | 000003T | | | | 1 - If PB | Notes . | | | #### **EXPRESSIONS** As described in Section 14 - Language Structure, expressions contain one or more terms (constants or symbols) joined by operators. #### **Operators** Expressions may contain arithmetic, logical, relational and shift operators. **Arithmetic operators**: Perform addition, subtraction, multiplication, and division operations: | Operator | Meaning | Example | Result (Octal) | |----------|----------------|---------|----------------| | + | Addition | `3+`4 | 000007 | | | Subtraction | 10-3 | 000005 | | * | Multiplication | `20*`10 | 000200 | | / | Division | '20/'10 | 000002 | **Logical operators**: Perform a logical operation on two 16-bit operands: | Operator | Meaning | Example | Result (Octal) | |----------|--------------|---------------|----------------| | .OR. | Logical OR | '123.OR.'456 | 000577 | | .XOR. | Logical | | | | | Exclusive OR | '123.XOR.'456 | 000575 | | .AND. | Logical AND | '123.AND.'456 | 000002 | | Relational operators: | Perform a | comparison | of two | 16-bit | operands | with | a result | of 0 if false | |-----------------------|-----------|------------|--------|--------|----------|------|----------|---------------| | and 1 if true. | | _ | | | • | | | | | Operator | Relation | Example | Result (Octal) | |----------|--------------|--------------|----------------| | .EQ. | Equal | `123.EQ.`123 | 000001 | | | | `123.EQ.`456 | 000000 | | .NE. | Not equal | `123.NE.`123 | 000000 | | | | `123.NE.`456 | 000001 | | .GT. | Greater than | `123.GT.`123 | 000000 | | | | `456.GT.`123 | 000001 | | .GE. | Greater than | `123.GE.`123 | 000001 | | | or equal | `123.GE.`456 | 000000 | | .LE. | Less than | `123.LE.`123 | 000001 | | | or equal | `123.LE.`456 | 000001 | | .LT. | Less than | `123.LT.`456 | 000001 | | | | `456.LT.`123 | 000000 | Shift operators: Perform logical right or left shift of an expression, using the syntax: $$\begin{array}{c} \text{argument-expression} \\ \text{(.RS.)} \end{array}$$ shift-count-expression | Operator | Meaning | Example | Result (Octal) | |----------|-------------|------------|----------------| | .LS. | Left shift | `123.LS.`3 | 001230 | | .RS. | Right shift | `123.RS.`3 | 000012 | #### Usage **Space conventions**: Operators may be preceded and/or followed by a single space (more than one space causes PMA to treat the rest of the line as a comment). Sign conventions: The operands for arithmetic operators may be signed. **Operator priority**: In expressions with more than one operator, the operator with the highest priority is performed first. In cases of equal priority, the evaluation proceeds from left to right. You may use parentheses to alter the natural order of evaluation. | Priority | Operator | |----------|----------------| | Highest | * / | | 1 | + - | | | .RSLS. | | | .GTGEEQNELELT. | | | .AND. | | 1 | .OR. | | Lowest | .XOR. | **Resultant mode**: For all operations other than addition and subtraction, the mode of both operands must be absolute and the result is absolute. When an addition operator is used, at least one of the operands must be absolute, and the result mode is the mode of the other operand. When a subtraction operator is used, at least the second operand must be absolute, and the result mode is the mode of the first operand. #### **LITERALS** A literal is an expression preceded by an equal-sign (=), as in: $$=$$ '37 $=$ \*+'37 You can use literals as operands in order to introduce data into your program. You cannot, however, use a literal as a term in an expression. The assembler places the data which you specified in a literal into a "literal pool". It then assembles the address of this literal into the object code of the instruction that contains the literal specification. Thus the assembler saves you a programming step by storing your literal data for you. Literals may be one or more words in length and may contain any legal data item or expression. Note, however, that if you use colon (:) or semicolon (:) in a character constant construction, you must precede it by an exclamation mark (!) escape character. # Non-SEG usage When RLIT is used after a FIN statement, literals which have been already collected in a literal pool by the FIN will not be redefined. For example: | | REL | | | | | | | |---|--------------------|-------------------------|------------------|------|-------------|--------|---------------------------------------------------| | _ | 22222 | go gagaga | (ØØØ1)<br>(ØØØ2) | | REL<br>RLIT | -1122 | '123 IS AN OCTAL LITERAL | | | 000000:<br>000001: | 02.000001<br>00.000123A | (ØØØ3)<br>(ØØØ4) | | LDA<br>FIN | ='123 | 123 15 AN OCIAL LITERAL | | * | 000002: | 02.000001 | (ØØØ5) | | LDA | ='123 | '123 IS IN THE SAME LITERAL<br>POOL AS '123 ABOVE | | | 000003: | 04.000005 | (0006) | | STA | BUFF | | | * | 000004: | 02.000006 | (ØØØ7) | | LDA | = '456 | '456 WILL BE IN BUFFER POOL<br>AFTER END | | | 000005: | 00.000010A<br>000006 | (ØØØ8)<br>(ØØØ9) | BUFF | DAC<br>END | '10 | DEFINE BUFFER AREA<br>END OF SOURCE CODE | | | 000005: | 00.000456A | | | | | | #### SEG usage Literals may be placed in either the procedure segment or in the linkage segment. If an RLIT pseudo-op is used, literals will be generated in the same way as in a non-SEG assembly with an RLIT. If an RLIT pseudo-op is not used, the literals will be placed in the linkage frame. The FIN pseudo-op may still be used to control the placement of literals. but the assembly origin at the time a FIN occurs can affect the literal placement. If RLIT mode is specified and a FIN occurs while in linkage origin, the FIN will act as: | HERE | EQU | * | |------|------|------| | | PROC | | | | FIN | | | | ORG | HERE | Correspondingly, if not in RLIT mode and a FIN occurs while in precedure origin, the FIN will have the effect of: HERE EQU \* LINK FIN ORG HERE #### ASSEMBLER ATTRIBUTES Assembler attributes can be specified by a number proceded by the pound character (#). The attribute number may be a variable, or an expression within parentheses, as long as such variables have been previously defined as absolute integer values. Attribute references are evaluated as absolute integer values, and may be used in both macro definitions and macro calls. See Appendix A for a complete list. 1 March, 1979 15–11 FDR 3059 # Pseudo-operations #### INTRODUCTION Pseudo-operation statements are commands to the assembler, rather than executable machine instructions. Pseudo-operation functions include: - Assembly control (AC) - Address definition (AD) - Conditional assembly (CA) - Data definition (DD) - Listing control (LC) - Literal (LT) - Loader control (LO) - Macro definition (MD) - Program linking (PL) - Storage allocation (SA) - Symbol definition (SD) Table 16-1 contains an alphabetical listing of all the pseudo-operations, their functional class and their restrictions, if any. Pseudo-operations have an operation field and an operand field separated by spaces. Labels are usually optional, but some pseudo-operations either require a label to be present, or prohibit it (see Figure 16-1). The operation field contains the mnemonic name that identifies the pseudo-operation. The operand field may contain one or more terms separated by single spaces or commas. Terms may be constants, symbols, or expressions as defined in Section 15. In certain operations, such as BCI, terms may also consist of ASCII character strings. Symbols used in the operand field must be previously defined. unless otherwise stated in the pseudo-operation definition. Address expressions are evaluated as 16-bit integer values and used as a 16-bit memory address, unless otherwise stated. Certain statements (DAC and XAC) accept indirect address (\*) and indexing (,1) symbols. These are interpreted according to the addressing mode which is in effect. | Name | Function | Class | Restriction | |-------------|------------------------------------------------------------|------------------|---------------------| | ABS | Set mode to absolute | AC | Not in SEG/SEGR | | 1100 | | | MODE | | AP | Argument pointer | $_{\mathrm{AD}}$ | SEG/SEGR mode | | BACK | Loop back | CA | Macros only | | BCI | Define ASCII string | DD | | | BES | Allocate block ending with symbol | SA | | | BSS | Allocate block starting with symbol | SA | | | BSZ | Allocate block set to zeros | SA | | | C64R | Check 64R | AC | | | CALL | External subroutine reference | PL | | | CENT | Conditional entry | LO | | | COMM | FORTRAN compatible COMMON | SA | | | D16S | Use 16S address mode | LO | | | D32I | Use 32I address mode | LO | | | D32R | Use 32R address mode | LO | | | D32S | Use 32S address mode | LO | | | D64R | Use 64R address mode | LO | | | D64V | Use 64V address mode | LO | | | DAC | Address definition (Prime 100–300) | AD | | | DATA | Define data constant | DD | | | DDM | Use default mode | LO | | | DEC | Define decimal integer constant | DD | | | DEC | Define table block | GA CA | | | DFVT | Define value table | CA | | | DUII | Define UII | LO | | | DYMN | Define stack relative symbol | SD | | | DYNT | Direct entry definition | PL | | | ECB | Entry control block | PL | SEG/SEGR mode | | | Eject page | LC | ono, onon modo | | EJCT<br>ELM | Enter loader mode | LO | | | ELSE | Reverse conditional assembly | CA | | | END | End of source statements | AC | | | ENDC | | CA | | | | End conditional assembly area End macro definition | MD | | | ENDM | | PL | | | ENT | Define entry point Outputs NOP if current address not even | AC | | | EVEN | | SD | | | EQU<br>EXT | Fixed symbol definition External reference | $_{ m PL}$ | | | FAIL | | CA | | | | Force error message<br>Insert literals | LT | | | FIN<br>GO | Forward reference | CA | | | | | DD | | | HEX | Define hexadecimal integer constant If table true | CA | | | IFTT | If table true<br>If table false | CA | | | IFTF | | CA<br>CA | | | IFVT | If value true | CA | | | IFVF | If value false | CA | | | IF | If true | CA<br>CA | | | IFx | Arithmetic conditional if | AD | SEG/SEGR mode | | IP | Indirect pointer | AC<br>AC | SEG/SEGR mode | | LINK | Put code in linkage segment | AC | OTICA OTICITE HIGHE | | LIR | Load if required | LO | | |------|------------------------------------------------------|----------|----------------------| | LIST | Enable listing | LC | | | LSMD | List macro expansions data only | LC | | | LSTM | List macro expansions | LC | | | MAC | Begin macro definition | MD | | | N64R | Not 64R | LO | | | NLSM | Don't list macro expansions | LC | | | NLST | Inhibit listing | LC | | | OCT | Define octal integer constant | DD | | | ORG | Define origin location | AC | | | PCVH | Print cross reference values in HEX | LC | | | PROC | Put code in procedure segment | $AC_{i}$ | SEG/SEGR mode | | REL | Set mode to relocatable | AC | Not in SEG/SEGR | | RLIT | Ontimiza litarala | LT | MODE | | SAY | Optimize literals Print message | MD | | | SCT | Select code within macro | MD | 等形式 医脱髓精膜 医皮肤 | | SCTL | Select code within macro Select code from macro list | MD | | | SDM | Set default mode | LO | | | SEG | Segmentation assembly – 64V | AC | Must be first | | OLG | oegmentation assembly of v | 710 | statement in listing | | SEGR | Segmentation assembly - 32I | AC | Must be first | | | | | statement in listing | | SET | Changeable symbol definition | SD | | | SETB | Set base sector | LO | | | SUBR | Define entry point | PL | | | SYML | Allows long external names | PL | SEG/SEGR mode | | VFD | Define variable fields | DD | | | XAC | External address definition | AD | | | XSET | Changeable symbol definition | SD | | 1 March, 1979 16-3 FDR 3059 # ASSEMBLY CONTROL PSEUDO-OPERATIONS (AC) Affect the actions of PMA during the assembly process. | Name | Function | Restriction | |------|--------------------------------------|------------------------------------| | ABS | Set mode to absolute | Not in SEG/SEGR mode | | C64R | Check 64R | | | END | End of source statements | 지전투 선생활 왕조는 기계는 본다 | | EVEN | Outputs NOP if current address even. | s not | | LINK | Put code in linkage segment | SEG/SEGR mode | | ORG | Define origin location | | | PROC | Put code in procedure segment | SEG/SEGR mode | | REL | Set mode to relocatable | Not in SEG/SEGR mode | | SEG | Segmentation assembly - 64V | Must appear before executable code | | SEGR | Segmentation assembly -32I | Must appear before executable code | # ABS Sets the assembly and loading mode to absolute, within the program address space. ABS may be terminated by REL and vice versa. ABS mode is the default assembly mode. # C64R Directs the assembler to flag any instructions and/or memory reference not compatible with 64R addressing mode. The following cases are detected: - 1. An indirect or indexed DAC - 2. An indirect, single-word memory reference instruction with an address that is neither in sector zero nor within the relative reach of the instruction. # [label] END [address-expression] Terminates assembly of the source program. All literals accumulated since either the start of the program, or the last FIN statement, are assigned locations starting at the current location count. If the program is segmented and literals are in the linkage segment, refer to Literal Control Pseudo-Operations for further information. If an **address-expression** is not specified, the first location of the first module becomes the start address: otherwise, the address-expression defines the start address. # ► [label] EVEN Outputs a NOP if the current address is not even. Forces even alignment only for the instruction or data immediately following the EVEN. #### LINK Places subsequent code in the linkage frame. The program counter value is set to one more than the highest value previously used in the linkage area. The mode is set to link. LINK may be terminated by PROC and vice versa. 1 March, 1979 16–5 FDR 3059 # ► [label] ORG address-expression Sets the assembler location count equal to the value of the address-expression. In non-SEG mode, the mode of the address-expression may be absolute, relative or common. The value of the program counter is set to the value of the expression. If the mode of the address-expression is common, then the mode of the program counter is set to common. If the mode of the program counter is common, then it is set to the mode of the address-expression. Otherwise, the mode of the program counter remains unchanged. In SEG-mode, the mode of the address-expression may be absolute, procedure relative, linkage or common. The value of the program counter is set to the value of the address-expression. If the mode of the address-expression is absolute, then the mode of the program counter remains unchanged. In all other cases whether relative, linkage, or common both the mode and the value of the program counter are set equal to that of the address-expression. # PROC Places subsequent code in the procedure segment. The value of the program counter is set to one more than the highest value previously used in the procedure segment. The mode is set to procedure relative. PROC may be terminated by LINK or vice versa. # REL Sets the assembly and loading mode to relocatable. REL may be terminated by ABS and vice versa. # **SEG** Directs the assembler to create a 64V segmented mode assembly module. SEG must appear before any instructions, pseudo-operations or macro calls which generate instructions, as well as before any DYNM pseudo-operations. D64V (q.v.) only governs instruction formats; it does not create a segmented module. Modules assembled in SEG mode must be loaded by SEG — the PRIMOS segmented loader utility. SEG has the following effects: - Sets the assembler into three pass assembly mode to optimize stack and link frame references. - Removes restrictions on placement of DYNM pseudo-operations. - Sets the instruction and address resolution mode to D64V. - Initializes the assembler program counter to procedure relative zero. #### SEGR Directs the assembler to create a 32I segmented mode assembly module. SEGR must appear before any instructions, pseudo-operations or macro calls which generate instructions, as well as before any DYNM pseudo-operation. D32I (q.v.) only governs instruction formats; it does not create a segmented module. Modules assembled in SEGR mode must be loaded by SEG — the PRIMOS segmented loader utility. SEGR has the following effects: - Sets the assembler into three pass assembly mode to optimize stack and link frame references. - Removes restrictions on placement of DYNM pseudo-operations. - Sets the instruction and address resolution mode to D32I. - Initializes the assembler program counter to procedure relative zero. # ADDRESS DEFINITION PSEUDO-OPERATIONS (AD) Create address constants which may be referenced by instruction statements. | Name | Function | Restriction | |------|-----------------------------|---------------| | AP | Argument pointer | SEG/SEGR mode | | DAC | Local address definition | | | IP | Indirect pointer | SEG/SEGR mode | | XAC | External address definition | | # [label] AP address-expression [,modifier] Generates an argument pointer in the form used by the 64~V/32I Procedure Call instruction (PCL). address-expression is an argument variable, written in memory reference address format. All 64V address forms may be used – except indexing. modifier controls the storage of address-expression as follows: - Set argument store bit. - SL Set argument store bit. Last argument. - \*S Set argument store bit. Argument is indirect. - \*SL Set argument store bit. Argument is indirect and last. - \* Intermediate indirect argument. Do not store. See Section 9 - Data Formats - for the argument pointer machine format. # ▶ [label] DAC address-expression Generates a 16-bit pointer in SR addressing format. **address-expression** is written in SR addressing format, with indirect addressing and indexing specified by \* and .1 respectively. If REL mode (see Assembly Control Pseudo-Operations) is in effect, the loader performs relocation during loading. The assembler generates a 16-bit constant which is acted upon by the loader as follows: | Addressing mode | Address Length | Index | Indirection | |-----------------|----------------|-------|-------------| | 16S | 14 | YES | YES | | 32S | 15 | NO | YES | | 32R | 15 | NO | YES | | 64R | 16 | NO | NO | | 64V | 16 | NO | NO | [label] DAC \*\* is a convention used to indicate a subroutine entry point (see Program Linking Pseudo-Operations). # [label] IP address-expression Generates a 32-bit 64V/32I indirect pointer. **address-expression** must be one of the following: procedure relative, linkage relative, common or external. SEG sets up the pointer at load time. # ► [label] XAC symbol Generates a 16-bit pointer to the external **symbol**. The symbol name may be the same as a local symbol without conflict. XAC is like a DAC except that it references external symbols. The address of the external symbol is filled in at load time. #### CONDITIONAL ASSEMBLY PSEUDO-OPERATIONS (CA) Enable the programmer to selectively assemble portions of a source file. | Name | Function | Restriction | |---------------------------|------------------------------------------|-------------| | BACK, | Loop back | Macros only | | BACK TO )<br>DFTB<br>DFVT | Define table block<br>Define value table | | | ELSE | Reverse conditional assembly | | | ENDC | End conditional assembly area | | | FAIL | Force error message | | | GO | Forward reference | | | IF | Conditional | | | IFx | Conditional | | | IFTF | If table false | | | IFTT | If table true | | | IFVF | If value false | | | IFVT | If value true | | $$\qquad \qquad [label-1] \left. \begin{cases} BACK \\ BACK \text{ TO} \end{cases} \right. label-2;$$ Directs the assembler to repeat source statements that have already been assembled. beginning with the statement specified by label-2. Such backward references are permitted only within a macro definition. Both the BACK, BACK TO and label-2 must lie within the same MAC-ENDM range. #### label DFTB (symbol, absolute-expression-1),... Creates a programmer symbol table. **label** is a table name, **symbol** is an argument whose value is **absolute-expression-1**. The symbols defined have no conflict with existing symbols. For example: There are no conflicts since the two X's and A's are different types. If a DFTB is defined with the same name as a previously defined table, the contents are appended to the previous table. #### label DFVT (absolute-expression-1, absolute-expression-2),... Creates a programmer value table. **absolute-expression-1** is the locator value and **absolute-expression-2** is the value to be substituted. #### ELSE Reverses the condition set up by an IFx statement until the matching ENDC statement is reached. If the IFx condition inhibited assembly, the ELSE statement enables assembly, and vice versa. ELSE statements that lie within the bounds of other IFx-ENDC pairs nested within the conditional assembly area are ignored. #### ENDC Defines the end of a conditional assembly area started by an IFx statement. Every IFx statement must have a matching ENDC. #### FAIL Generates an F error in the listing. #### [label] IF absolute-expression, statement Provides the ability to selectively assemble code based on the results of a test. The operand consists of an **absolute-expression** followed by a **statement**. If the expression is true (has a non-zero result) the statement is assembled; otherwise the statement is ignored and the next line is processed. The operand of the IF statement cannot be continued onto the following line, because the skip-if-false condition proceeds to the next physical, rather than logical, line. Sets specific tests to control code assembly. The **absolute-expression** is evaluated, and if the result corresponds to the IF condition, assembly proceeds normally. Otherwise, the assembler ignores all subsequent statements until an ENDC or ELSE statement is reached. For every IFx statement there must be a matching ENDC statement. IFx and ENDC pairs may be nested within each other. The nesting depth count is checked even in sections of code that are being skipped by a previous IFx statement. #### label IFTF symbol Searches the table, whose name is **label**, for **symbol**. If symbol is not found, puts its value in assembler attribute 124 and assembles code to the matching ELSE or ENDC. If the symbol is found, skip to the line following the matching ELSE or ENDC. #### label IFTT symbol Searches the table, whose name is **label**, for **symbol**. If symbol is found puts its value in assembler attribute 124 and assembles code to the matching ELSE or ENDC. If the symbol is not found, skip to the line following the matching ELSE or ENDC. #### label IFVF symbol Obtains a value in a value table. If **symbol** does not equal a locator value in the value table whose name is **label**, put its value in assembler attribute 124 and assemble the code to the matching ELSE or ENDC. If the locator value is found, skip to the line following the matching ELSE or ENDC. #### label IFVT symbol Obtains value in a value table. If **symbol** equals a locator value in the value table whose name is **label**, puts its value is assembler attribute 124 and assembles the code to the matching ELSE or ENDC. If the locator value is not found, skip to the line following the matching ELSE or ENDC. ### $\qquad \left\{ \begin{array}{c} \mathbf{GO} \\ \mathbf{GO} \ \mathbf{TO} \end{array} \right\} \mathbf{label}$ Causes suspension of assembly of all subsequent statements until a statement having the specified **label** is found. The GO or GO TO statement must point forward to a label that is not yet defined. An error condition exists if the assembler reaches an END, MAC, or ENDM statement before finding the specified label. #### DATA DEFINING PSEUDO-OPERATIONS (DD) Initialize memory locations to known starting values. For coding convenience, data and address constants may be specified in a variety of formats. Simple coding conventions allow the programmer to use decimal, octal, binary and hexadecimal integers, decimal floating point, and ASCII character constants. The assembler interprets the notation and automatically generates one, two or more data words in the proper internal binary format. | Name | Function | Restriction | | |------|-------------------------------------|-------------|--| | BCI | Define ASCII string | | | | DATA | Define data constant | | | | DEC | Define decimal integer constant | | | | HEX | Define hexadecimal integer constant | | | | OCT | Define octal integer constant | | | | VFD | Define variable fields | | | # [label] BCI \ 'string' \ (n, string \) Loads ASCII character strings by packing the specified ASCII characters two per word, starting with the most significant 8 bits. Assembled words are loaded starting at the current location count. In the first format, the **string** is delimited by any character other than a digit. If an odd number of characters is specified, the least significant half of the last word is filled with zeroes. In the second format, the **string** is preceded by a word count, $\mathbf{n}$ , which is the number of characters divided by two and rounded up. #### [label] DATA [(absolute-expression-1)] absolute-expression-2, . . . Defines absolute-expression-2 absolute-expression-1 times. Absolute-expression-1 is assumed to be 1 if omitted. The operand expression(s) are assembled into the current location. The operand may contain any number of subfields, separated by commas. Subfields are assembled in consecutive locations starting with the left-most subfield. If an expression requires more than one location (e.g. floating point), consecutive locations are used. See Section 15 – Data Definition – for a full discussion of allowable formats. #### [label] DEC decimal-integer-constant, . . . Defines decimal integers. Each **decimal-constant** in the operand is evaluated as a decimal constant, converted into one or more binary words, and loaded starting at the current location. All numeric formats accepted by the DATA statement may be used with DEC. #### [label] HEX hexadecimal-integer-constant, . . . Defines hexadecimal integers by converting the **hexadecimal-constants** within the operand to 16-bit integer values and loading them in consecutive locations starting at the current location. #### [label] OCT octal-integer-constant, . . . Defines octal integers. Each **octal-constant** in the operand is loaded at the current location. #### ▶ [label] VFD absolute-expression-1, absolute-expression-2, . . . Permits 16-bit data words to be formed with subfields of varying length. In the pairs of constants, **absolute-expression-1** gives the subfield size, **absolute-expression-2** gives the value. The first pair is the most significant subfield; subsequent field size value pairs load less significant subfields of the 16-bit word. For any pair, if a value exceeds the specified field size, the more significant overflow bits are exclusive-OR'ed with the subfield to the left. No error message is generated. If the entire word is not specified, the least significant end is filled with zeroes. An error message is printed if the assembler attempts to load more than 16 bits. #### LISTING CONTROL PSEUDO-OPERATIONS (LC) Format the assembler listing. | Name | Function | Restriction | |------|----------------------------------------|-------------| | EJCT | Eject page | | | LIST | Enable listing | | | LSMD | List macro expansions data only | | | LSTM | List macro expansions | | | NLSM | Don't list macro expansions | | | NLST | Inhibit listing | | | PCVH | Print cross reference values in hexade | ecimal | #### EJCT Causes the listing device to eject the page (execute a form feed), print the current page title and page number, and feed three blank lines before resuming the listing. This function is operable *only* with devices having a mechanical form feed capability, such as a line printer. #### LIST Lists all statements except those generated by macro expansions. Since this is the assembler's default mode, a LIST statement is not required unless a NLST statement has previously inhibited listing. #### ► LSMD Lists macro calls plus any data generated by macros. #### **▶** LSTM Lists macro call statements plus all lines generated by the macro expansion including code and data values. #### NLSM Inhibits listing of statements generated by macro expansion. Only the macro call is listed. Ignored if -EXPLIST command line option is specified. #### NLST Inhibits listing of all subsequent statements until a LIST statement is encountered. LIST and NLST may be used together in source text for selective control over the sections to be listed. The LSTM, LSMD, and NLSM statements provide control of listing for macro definitions. Ignored if –EXPLIST command line option is specified. #### PCVH Prints symbol values in the cross reference in hexadecimal instead of octal. #### LITERAL CONTROL PSEUDO-OPERATIONS (LT) Govern the placement of literals. Also see END, which is described under Assembly Control Pseudo-Operations. | Nan | ne Function | Restriction | |-----|-------------------------|-----------------------------------------| | FIN | Insert literals | 조망 및 발표되는 학교를 다 맞으면 그는 모든 그 나를 다 보다 다니? | | RLI | <b>r</b> Optimize liter | als | #### [label] FIN Controls the placement of literal pools. All literals defined since an RLIT statement, the start of the program, or the last FIN statement, are assembled into a literal pool starting at the current location. Processing of subsequent statements begins at the first location following the literals. By using FIN, the programmer can distribute literals throughout the program, and possibly reduce the number of out-of-range indirect address links that must be formed by the loader to access literals. #### [label] RLIT Directs the assembler to optimize literal allocation for relative addressing modes (32R, 64R, 64V, 32I modes). Normally (i.e., without RLIT), literals are assigned locations following a FIN or END statement. If a defined literal is referenced following a FIN, it is assigned another location following the next FIN or END statement. However, in a program that contains an initial RLIT, a literal that has already been defined and is still within the relative or multiword reach (see Section 10 – Memory Reference) is referenced directly, without allocating a new location. #### Note RLIT must precede executable code. Normally in SEG or SEGR mode, literals would be placed in the linkage segment; issuance of RLIT causes placement of literals in the procedure segment. Usage (non-SEG or SEGR): When RLIT is used with a FIN statement, literals which have been already collected in a literal pool by a FIN will not be redefined. For example: | | RE | CL , | | | | | | |---|---------|------------|--------|------|------|-------|---------------------------------------------------| | _ | | | (0001) | | REL | | | | | | | (0002) | | RLIT | | | | | 000000: | 02.000001 | (ØØØ3) | | LDA | ='123 | '123 IS AN OCTAL LITERAL | | | 000001: | 00.000123A | (0004) | | FIN | | | | * | 000002: | 02.000001 | (ØØØ5) | | LDA | ='123 | '123 IS IN THE SAME LITERAL<br>POOL AS '123 ABOVE | | | 000003: | 04.000005 | (0006) | | STA | BUFF | | | | 000004: | 02.000006 | (0007) | | LDA | = 456 | '456 WILL BE IN BUFFER POOL | | * | | | | | | | AFTER END | | | ØØØØØ5: | 00.000010A | (0008) | BUFF | DAC | '1Ø | DEFINE BUFFER AREA | | | | ØØØØØ6 | (ØØØ9) | | END | | END OF SOURCE CODE | | | ØØØØØ6: | 00.000456A | | | | | | **Usage (SEG/SEGR):** The FIN pseudo-operation may still be used to control the placement of literals, but the assembly origin at the time a FIN occurs and the use of RLIT can affect the literal placement. If RLIT is specified and a FIN occurs while in linkage origin, the FIN will act as: Correspondingly, if RLIT is not specified and a FIN occurs while in procedure origin, the FIN will have the effect of: #### LOADER CONTROL PSEUDO-OPERATIONS (LO) Provide control information for the loader. Addressing mode control pseudo-operations (D16S, D32S, D64R, D64V, D32I) control the assembler memory reference instruction processing as well as loader address resolution mode. Mode commands entered during loading set the loader's current mode only, and are overridden by mode control pseudo-operations in the program. Incompatible instructions (e.g., a 64V instruction in 32R mode), are flagged by the assembler. The default mode of the assembler is relative, unless a SEG pseudo-operation is used, in which case 64V mode is the default. Note that DUII, LIR and CENT simplify the preparation of library packages that automatically load the modules appropriate to the machine in which the code is to be executed. | Name | Function | Restriction | |------|-------------------------|----------------| | CENT | Conditional entry | | | D16S | Use 16S addressing mode | | | D32S | Use 32S addressing mode | | | D32R | Use 32S addressing mode | | | D64R | Use 64R addressing mode | | | D64V | Use 64V addressing mode | | | D32I | Use 32I addressing mode | | | DDM | Use default mode | | | DUII | Define UII | | | ELM | Enter loader mode | | | LIR | Load if required | | | N64R | Not 64R | | | SDM | Set default mode | Not 64V or 32I | | SETB | Set base sector | | #### CENT symbol Provides a conditional ENT capability. The loader will load a module containing a CENT only if something else in the module — such as an LIR — tells it to load the module. This is true even if the CENT **symbol** matches an unresolved external reference. Typically, a module containing a CENT will be part of a library. #### D16S Directs the assembler and the loader to use 16R address resolution. #### D32R Directs the assembler and the loader to use 32R address resolution. #### D32S Directs the assembler and the loader to use 32S address resolution. #### D64R Directs the assembler and the loader to use 64R address resolution. #### D64V Directs the assembler and the loader to use 64V address resolution. #### D321 Directs the assembler and the loader to use 32I address resolution. #### DDM Directs the assembler and the loader to use the default addressing mode. The default mode is initially set at the start of a load and is only changed by a SDM pseudo-operation. #### DUII absolute-expression-1, absolute-expression-2 Triggers the loading of a UII package. **absolute expression-1** is a bit mask, defining instruction sets that the UII package emulates, and **absolute-expression-2** is a bit mask, defining hardware instruction sets that must be present to execute the UII package. #### Bit number Meaning | 1-9 | Must be 0 | |-----|---------------------------------| | 10 | Prime 450 and up | | 11 | Prime 300, 400 | | 12 | Undefined | | 13 | Double Precision Floating Point | | 14 | Single Precision Floating Point | | 15 | Prime 300 Only | | 16 | High Speed Arithmetic | #### **►** ELM Causes the loader to generate an enter addressing mode instruction in the current loader addressing mode at the current counter. #### LIR absolute-expression Controls library program loading. The program will be loaded if any of the instruction groups specified have been used in previously loaded code. **absolute-expression** is a bit mask, defining instruction groups that are to trigger loading. Bit assignments are the same as for DUII. #### [label] N64R Informs the loader that the program is not to be loaded in the 64R addressing mode. If such a program is loaded in the 64R addressing mode, the loader will report a 'N6' error. #### SDM absolute-expression Directs the loader to set its default addressing mode to **absolute-expression**. Legal values of the expression are: 16S Mode 32S Mode 64R Mode 32R Mode SDM does not change the current addressing mode and cannot be used in 64V or 32I modes. #### ▶ [label] SETB address-expression-1, absolute-expression-2 Specifies the starting-address address-expression-1 and the size absolute-expression-2 of a base area for out-of-range indirect address links. Normally, the loader generates address links starting at location '200 of sector zero. This statement permits the loader to generate address links in the same sector as the instruction which refers to them. Memory locations to be used for this purpose must be reserved by the program. The first SETB for a given base area determines the location at which the indirect word table will begin in that sector. The table then grows upward (increasing addresses). Other SETB pseudo-operations referencing the same sector do not redefine the table for that sector — table filling resumes where it left off. At the end of each module, the base sector reverts to sector zero. The loader maintains a record of the last location used in each base sector. When the base sector reverts to zero, no indirect words are lost. #### MACRO DEFINITION PSEUDO-OPERATIONS (MD) Create macros. See Conditional Assembly and Listing Control Pseudo-Operations for other MACRO specific pseudo-operations. | Name | Description | |------|------------------------------------| | ENDM | End macro definition | | MAC | Begin macro definition | | SAY | Print message | | SCT | Select code within macro | | SCTL | Select code from list within macro | | | ENDM<br>MAC<br>SAY<br>SCT | #### **ENDM** Terminates assembly of a macro definition. ENDM must be the last statement in a macro definition — just as END is the last statement in an assembler program. Begins the definition of the macro named by the label field. The name is formed in the same way as any variable or label. Following MAC are statements that make up the **macro definition**; for example: The integers enclosed in angle brackets are **argument references**. During assembly they are replaced by **argument values** specified in a **macro call**. Optional **dummy words** ("noise words") and argument identifiers ("positional noise words") are described in Section 17 — Macro Facility. Macro definitions may contain macro calls to any depth, but macro definitions themselves cannot be nested. #### ► [label] SAY ASCII-expression Defines a message which is printed starting in columnm 1 of the listing. Normally, the SAY message is used within a macro to generate error comments or other messages. Macro argument references, enclosed by angle brackets are replaced by their equivalent character string before output. If a listing device is assigned, SAY statements generate output regardless of the status of the listing options. #### [label] SCT absolute-expression Assembles selected code groups based on **absolute-expression**. The expression must be a constant or an expression that can be evaluated as a single-precision number. The argument value may be positive or negative, with a range to $\pm$ 4000. This value determines which code groups are assembled. **Code groups**: Code using SCT must be in groups delimited by marker lines, which have a percent symbol (%) in column 1 followed by a numeric argument: | Marker | Meaning | |------------|--------------------------------------------------------------------------------------------------------| | 070 | Ordinary marker line. | | %1 | If the preceding section of code was assembled, continue assembly from this marker to the next marker. | | % <b>2</b> | If no other sections of code have been assembled, assemble from this line to the next marker. | | % / | End of control range. | The %2 marker is useful to identify a section of code that is to be assembled if the argument value of the SCT statement is out of range. | Argument<br>Value | Assembly Condition | |-------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 0 | Assemble from the SCT statement to the first $\%$ marker; then skip to the $\%$ / line. | | 1 | Skip to the first $\%$ marker; assemble from there to the second $\%$ marker; then skip to the $\%$ / marker. | | n | Skip to the n'th $\%$ line marker, if any; assemble from there to marker n +1; then skip to the $\%$ / marker. If there is no n'th $\%$ marker, proceed as for -n. | | -n | Skip to a $\%2$ line marker, if any, and assemble from there to the next $\%$ marker; then skip to the $\%$ line. If there is no $\%2$ marker, skip to the $\%$ line. | No other SCT statements may appear within the control range; SCT statements cannot be nested. It is possible, however, to call another macro containing an SCT from within an SCT area. #### [label] SCTL absolute-expression-1, absolute-expression-2, . . . Assembles selected code groups. The results of a comparison between the first **absolute-expression-1** and the rest of the argument list controls the selection of the code group. Absolute-expression-1 and each expression in the argument list must be a constant or an expression that can be evaluated as a single-precision number. The argument value may be positive or negative, with a range to $\pm$ 4000. This value determines which code groups are assembled. **Code groups**: Code using SCTL must be in groups delimited by marker lines, which have a percent symbol (%) in column 1 followed by a numeric argument: 1 March, 1979 16–17 FDR 3059 | Marker | Meaning | |--------|--------------------------------------------------------------------------------------------------------| | | Ordinary marker line. | | %1 | If the preceding section of code was assembled, continue assembly from this marker to the next marker. | | % 2 | If no other sections of code have been assembled, assemble from this line to the next marker. | | % / | End of control range. | The %2 marker is useful to identify a section of code that is to be assembled if the argument value of the SCTL statement is out of range. | Argument | | |----------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | Value | Assembly Condition | | 0 | Assemble from the SCTL statement to the first $\%$ marker; then skip to the $\%$ / line. | | 1 | Skip to the first $\%$ marker; assemble from there to the second $\%$ marker; then skip to the $\%$ / marker. | | n | Skip to the n'th $\%$ line marker, if any; assemble from there to marker n +1; then skip to the $\%$ / marker. If there is no n'th $\%$ marker, proceed as for -n. | | -n | Skip to a $\%2$ line marker, if any, and assemble from there to the next $\%$ marker; then skip to the $\%$ / line. If there is no $\%2$ marker, skip to the $\%$ line. | **Expression comparison**: The position on the argument list of the expression which equals absolute-expression-1 determines the result: | Expression Position | Meaning | |---------------------------------------------|---------| | absolute-expression-1=absolute-expression-2 | SCT 0 | | absolute-expression-1=absolute-expression-n | SCT n | | no match | SCT -n | No other SCTL statements may appear within the control range; SCTL statements cannot be nested. It is possible, however, to call another macro containing an SCTL from within an SCTL area. #### PROGRAM LINKING PSEUDO-OPERATIONS (PL) Coordinate the interaction of the assembler and loader in resolving address references between main programs and external subroutines. | Name | Function | Restriction | |-------|-------------------------------|-------------| | CALL | External subroutine reference | | | DYNT | Direct entry call | | | ECB | Define entry control block | SEG/SEGR | | EXT | Flag external reference | | | SUBR, | | | | ENT | Define entry point | | #### [label] CALL symbol In non-64V modes, CALL generates a JST to symbol, which is defined by the assembler as external. Unlike EXT, there is no conflict between a local variable and a CALL operand with the same symbol. The operand must contain a single symbol (not an expression) of up to 6 characters, of which the first must be alphabetic. A ,1 for indexing and \* for indirect addressing is optional. In 64V and 32I modes, CALL generates a PCL instruction to an external symbol. #### DYNT address-expression Defines a direct entry point into the operating system. System libraries only. # [label] ECB entry-point, [link base], displacement, n-arguments [, stack-size] [, keys] Generates an entry control block to define a procedure entry. It must go in the linkage frame with the subroutine entry point pointing to the ECB. | Parameter | Meaning | |--------------|----------------------------------------------------------------------------------------------| | entry-point | Procedure relative value; entry point for subroutine. | | link-base | Link base register value. | | displacement | Displacement in stack frame for argument list. May be stack relative or absolute expression. | | n-arguments | Number of arguments expected; default is zero. | | stack-size | Initial stack frame size. Default is maximum area specified in DYNM statements. | | keys | CPU keys for procedure. Default is 64V addressing mode, all other keys zero. | For example: If the default value for a parameter is desired, the parameter may be omitted, leaving only its delimiting comma. Any string of trailing commas may be omitted. #### Note The main program — that which you call PRIMOS level using SEG#Name — is a subroutine to SEG and must, therefore, have an ECB and the ECB name on the END statement. It need not have an ENT because SEG will give a dummy entry point name to a routine called at this level. #### ► [label] EXT symbol Identifies external variables. The names appearing in the operand of this statement are flagged as external references. Whenever other statements in the main program reference one of these names, a special block of object text is generated that notifies the loader to fill in the address properly. The assembler fills the address fields with zeroes. Names defined by the EXT pseudo-operations are unique only in the first 6 characters (loader restriction) and should not appear in a label field internal to the program. #### [label] SUBR symbol-1 or ENT symbol-1 [, symbol-2] Link subroutine entry points to external names used in CALL, XAC or EXT statements in calling programs. SUBR and ENT are identical in effect. **symbol-1** is the external name used by calling program, whereas, **symbol-2** is the entry name used in subroutine, if different from symbol-1. SYML SEG/SEGR Allows long external names up to eight characters to be generated by the assembler. Must follow SEG or SEGR but precede any generated code. #### STORAGE ALLOCATION PSEUDO-OPERATIONS (SA) Control the allocation of storage within the program address space. | Name | Function Restriction | | |------|-------------------------------------|----| | BSS | Allocate block starting with symbol | | | BES | Allocate block ending with symbol | | | BSZ | Allocate block set to zeroes | | | COMM | FORTRAN compatible COMMON | Á. | Allocates a block of words of the size specified in the **absolute-expression** starting at the current location count. If there is a label, it is assigned to the first word of the block (BSS and BSZ) or to the last word of the block (BES). For BSZ, all words within the block are set to zeroes. #### [label] COMM symbol [(absolute-expression)] Defines FORTRAN-compatible named COMMON areas. These areas are allocated by the loader. The **label** assigns a name to the block as a whole, and the operand field specifies named variables or arrays within the block. Additional COMM statements with the same block name are treated as continuations. **symbol** alone reserves a single location; the optional **absolute-expression** reserves locations equal to its value. In SEG mode, the loader sets up a 32-bit indirect pointer in the linkage segment which points to the common area. #### SYMBOL DEFINING PSEUDO-OPERATIONS (SD) Variables used as address symbols are usually defined when they appear in the label field of an instruction or pseudo-operation statement. Symbols so defined are given the relocation mode and value of the program counter at that location. The EQU, SET and XSET statements make it possible to equate symbols to any numerical value, including ones that lie outside the range of addresses in a program. | Name | Function | Restrictions | |------|------------------------|--------------| | DYNM | Declare stack relative | R and V only | | EQU | Symbol definition | | | SET | Symbol definition | | | XSET | Symbol definition | | # DYNM [absolute-expression-1,] [symbol] [(absolute-expression-2)] [=absolute-expression-3], . . . ] Declares stack relative symbols. Since references to stack relative symbols generate two-word instructions, stack relative symbols must be declared before they are used (REL mode only). **expression-1** is the stack size, **symbol** is the name, **expression-2** is the number of words to allocate for that symbol and **expression-3** is the stack offset. In the following format descriptions, these abbreviations are used: sc Current stack allocation count (initially=2) #### Note Initially '12 in SEG mode. Note also that subroutine argument addresses require three words and are specified: ARGn(3). | sm | Maximum allocation count | |--------|------------------------------------------------| | symbol | Symbol to be assigned stack relative offset | | exp1 | Expression defining number of words for symbol | | exp2 | Expression defining stack offset | #### Format Description - 1. symbol - symbol is assigned offset=sc - sc=sc+1 - if (sc .GT. sm) sm=sc - 2. symbol (exp1) - symbol is assigned offset=sc - sc=sc+exp1 - if (sc .GT. sm) sm=sc - 3. symbol=exp2 - symbol is assigned offset=exp2 - if (exp2+1 .GT. sm) sm=sc - 4. symbol (exp1)=exp2 - symbol is assigned offset=exp2 - if $(\exp 2 + \exp 1 \cdot GT. sm) sm = \exp 2 + \exp 1$ - $5. = \exp 2$ - sc=exp2 In format 1, the **symbol** in the field label is equated to the **absolute-expression**. which may be any expression which is legal in the current addressing mode. Any symbols used in the expression must already be defined. In format 2, symbols are assigned numerical values by equality expressions in the operand field. One or more equality expressions can be used, separated by commas. #### 16 Note that format 1 can be extended by **symbol=value** expressions. EQU, SET and XSET perform the same functions; however, a symbol defined by EQU may not be redefined, while a symbol once defined by SET or XSET may be redefined by subsequent SET or XSET statements without causing an error message. Symbols defined by XSET will not appear in the cross reference listing. #### INTRODUCTION The macro facility enables the programmer to define functions using simple English, or other language phrases. For example, the macro: TRANSFER DATA TO SAVE replaces the simple but cryptic assembly coding: LDA DATA STA SAVE Once a macro function has been defined, it can be called any number of times within a program. Different argument values (DATA and SAVE in the above example) can be supplied with each call. Dummy words, such as TO or FROM, can be added to increase intelligibility. These words must be identified during macro definition so that they will not be treated as additional arguments in a macro call. After a system-level programmer has defined a set of macros, a specialist in an application field can formulate macro calls to solve his particular problems. The application specialist gains the advantage of macro's capabilities without becoming involved in the details of assembly language programming. The example below illustrates a simple macro definition and call. The discussion which follows describes each element. | RE | L | | | | | |---------|-----------|--------|----------|-------|---------------| | | | (0001) | | REL | | | | | (ØØØ2) | | LSTM | | | | | (ØØØ3) | TRANSFER | MAC | | | | | (0004) | | LDA | <1> | | | | (ØØØ5) | | STA | <2> | | | | (0006) | | ENDM | | | | | (ØØØ7) | | TRANS | FER DATA SAVE | | øøøøøø: | 02.000002 | (MLØl) | | LDA | DATA | | 000001: | 04.000003 | (MLØl) | | STA | SAVE | | | | (MLØl) | | ENDM | | | 000002: | ØØØØØ5 | (ØØØ8) | DATA | OCT | 5 | | ØØØØØ3: | | (ØØØ9) | SAVE | BSS | 2 | | | 000005 | (0010) | | END | | #### MACRO DEFINITION Each macro definition must begin with a MAC pseudo-operation. The MAC statement must have a label ('TRANSFER') and may have optional dummy words ('FROM' 'TO') and argument identifiers in the variable field. Statements which make up the macro definition follow, terminated by an ENDM pseudo-operation. #### Argument references Argument references are expressions enclosed within angle brackets. Any field of a statement within a macro definition may contain an argument reference. The expression may contain variables as well as absolute integers, provided the variable has been previously defined as an absolute integer. For example: ``` REL LSTM TRANSFER MAC LDA <J> STA <K> ENDM J EQU 1 K EQU 2 ENDM ``` is the same as the previous transfer macro example. The label field of the macro call is not automatically assigned; it replaces argument <0>, if any, during assembly. #### Assembler attribute references Certain useful attributes of a macro can be specified by a number preceded by the pound character (#). The attribute number may be a variable, or an expression within parentheses, as long as such variables have been previously defined as absolute integer values. Attribute references are evaluated as absolute integer values, and may be used in both macro definitions and macro calls. See Appendix A for a complete list. #### Local labels within macros Local labels, which do not conflict with labels outside of the macro, can be assigned within a macro definition by using the ampersand character (&) as the first character of the label. The ampersand is replaced by a 4-digit macro call number, thereby assuring uniqueness of the label regardless of the macro's environment. Use of the ampersand outside of a macro will result in the substitution of 4 zeros. Examples: | Assigned | | | |-------------|----------------------|---------------| | Local Label | <b>Evaluation As</b> | In Macro Call | | ABC | 002ABC | 0002 | | X3A | 1739X3A | 1739 | #### MACRO CALLS A macro call is a special type of statement that uses the name of a defined macro in the operation field: ``` [label] macro-name arguments, ... dummy words, ... argument identifiers, ... ``` For each macro call, the assembler enters the in-line code of the defined macro starting at the current location. Argument references are replaced by argument values from the variable field. User defined macros must be defined in source statements preceding the macro call. #### Argument values The variable field of a macro call usually contains one or more argument value expressions. An argument value expression begins with the first non-space character of the variable field and continues until either a terminating comma or space appears. The comma or space is not considered to be part of the argument expression. Argument values in parentheses: Enclose argument value expressions in parentheses when commas, spaces, or string delimiters within a single argument are desired. The outside parentheses are not considered as part of the argument expression. A typical use of this feature is in forming sub-lists of arguments for macro calls nested within a given macro definition. See NESTING MACROS, below. #### Argument substitution During assembly of a macro call, the assembler substitutes the argument values in the macro call variable field for the argument references in the macro definition. Argument expressions are matched to argument references in numerical order from left to right. The first expression in the macro call is assigned as argument 1, the second as argument 2, and so on. | Variable Field | Argument <1> | Argument <2> | Argument <3> | |-------------------|---------------|--------------|--------------| | A | A | 0 | 0 | | A+3 | A+3 | 0 | 0 | | $X, Y-1, Z^*A-1$ | X | Y-1 | Z*A-1 | | X,B-C (Z3X2) | X | B-C | Z3X2 | | (A, B-1), C | A, B-1 | С | | | (X, Y, (Z1+Z2),3) | X,Y,(Z1+Z2),3 | 0 | 0 | In the following call to the TRANSFER macro. the variable ARG1 is argument 1 and the constant '1770 is argument 2. Thus, the TRANSFER macro shown would be assembled as: Arguments that are not assigned values in a macro call are set to zero by the assembler. #### Self documentation of macros An ordinary macro call like: #### TRANSFER ARG1 ARG2 although complete, provides only a vague description of its function. Using additional words in the variable field of a macro call, the programmer can communicate the exact nature of the function. Macro calls are made self-documenting by a combination of meaningful argument symbols, such as DATA, MESSAGE, and PRINTER, dummy words, such as TO and FROM, and argument identifiers. Dummy words are for descriptive purposes only and are ignored by the assembler, while argument identifiers act as argument keywords. **Dummy words**: Dummy words applicable to a given macro are defined in the variable field of the MAC statement that starts the macro definition. For example: ``` TRANSFER MAC FROM TO LDA <1> STA <2> ENDM ``` In the above example, FROM and TO are defined as dummy words. In any subsequent call to this macro, the assembler ignores the words FROM and TO; all other expressions in the variable field are interpreted as argument values, proceeding in numerical argument order from left to right. These values are substituted for the argument references in the macro definition statements, e.g., when the TRANSFER macro is called by TRANSFER FROM ALPHA TO '7770, the assembler ignores the FROM and TO, and assembles the macro as if the call statement were TRANSFER ALPHA, '7770. A dummy word string can be any combination and number of letters, numerals, periods and \$ signs, terminated by a comma. Any number of dummy word strings may be used. If the first character of a dummy word string is an open parentheses, all characters, including spaces and commas, up to the closing parentheses are considered part of the same string. The parentheses are not considered part of the string. **Argument identifiers**: While the self-documenting effect of dummy words improves the description of macro calls, the programmer must still be careful to enter values for arguments in the proper order. Argument identifiers increase the format flexibility of macro calls by associating a particular argument number with a specific dummy word, regardless of written order. In the TRANSFER macro, for example, identifiers can be defined so that argument 2 follows the dummy word TO, and argument 1 follows FROM, regardless of the order in which TO and FROM appear in a macro call. Argument identifiers, like dummy words, are assigned in the variable field of a MAC statement that starts a macro definition. To define an argument identifier, set a dummy word, in parentheses, equal to the desired argument number: ``` TRANSFER MAC (FROM)=1 (TO)=2 LDA <1> STA <2> ENDM ``` When a call to the macro uses a defined argument identifier in its variable field, the first non-dummy expression immediately following the identifier is taken as the value of the argument: | RE | Ĺ | | | | | |---------|-----------|--------|----------|-------|-------------------------| | _ | | (0001) | | REL | | | | | (ØØØ2) | TRANSFER | MAC | (FROM) = 1, (TO) = 2 | | | | (ØØØ3) | | LDA | <1> | | | | (0004) | | STA | <2> | | | | (0005) | | ENDM | | | | | (0006) | | TRANS | SFER FROM ALPHA TO BETA | | ØØØØØØ: | 02.000004 | (MLØl) | | LDA | ALPHA | | 000001: | 04.000006 | (MLØl) | | STA | BETA | | | | (0007) | | TRANS | SFER TO BETA FROM ALPHA | | 000002: | 02.000004 | (MLØl) | | LDA | ALPHA | | 000003: | 04.000006 | (MLØ1) | | STA | BETA | | 000004: | | (0008) | ALPHA | BSS | 2 | | ØØØØØ6: | | (ØØØ9) | BETA | BSS | 2 | | | 000010 | (0010) | | END | | Both of these calls have the same effect. The expression following the dummy word FROM is taken as argument <1>, and the expression following TO is taken as argument <2>. Argument identifiers and dummy words may be used together in the same macro. Ordinary dummy words are ignored, as usual. Arguments that are not associated with identifier words receive values in the usual positional priority – the first non-dummy word is taken as the value for the first unspecified argument, and so on. For example, the macro defined by: can be called by, ``` (ØØØ1) REL (0002) MASK MAC (BY)=2, (TO)=3, MOVE, AND (ØØØ3) LDA <1> (0004) ANA <2> <3> (ØØØ5) LDA (0006) ENDM (0007) MASK INPUT BY 7 AND MOVE TO BUFFER 000000: 02.000003 (MLØ1) LDA INPUT 000001: 03.000007A (ML01) ANA 7 000002: 02.000004 (MLØ1) LDA BUFFER 000003: 000456 (ØØØ8) INPUT OCT. 456 000004: (0009) BUFFER BSS 1 000005 (0010) END ``` Using the identifier words BY and TO, argument 2 is given a value of 7 and argument 3 is equated to the label BUFF1. The only remaining variable in the call is INPUT, so it is assigned as to the first unspecified argument, 1. #### **NESTING MACROS** Macro definitions may contain nested calls, as in the following example: The WAIT1 macro, which calls another macro, TRANSFER, is defined by: ``` TRANSFER MAC LDA <1> STA <2> ENDM WAIT MAC IRS <1> JMP *-1 TRANSFER <2> ``` ENDM is called by, ``` REL TRANSFER MAC <1> LDA STA <2> ENDM WAIT MAC IRS <1> JMP *-1 TRANSFER <2> ENDM WAIT 100, (INPUT, SAVE) BSS 2 INPUT SAVE BSS 2 END ``` is assembled as: ``` WAIT 100, (INPUT, SAVE) ``` Macro definitions may not, however, contain nested macro definitions. #### CONDITIONAL ASSEMBLY There are a number of pseudo-operations which allow the programmer to control the assembly of his macro. These pseudo-operations are discussed in the Conditional Assembly Pseudo-operation section. #### **MACRO LISTING** Three levels of listing detail for macro calls are available. | LSTM | Lists macro statements and all lines generated by expansion of the | |-------|--------------------------------------------------------------------| | | macro, including code or data values. | | LSTMD | Lists macro call statements and any lines which generate code. | | NLSM | Inhibits the list of macro expansions. Only the call is listed. | The default condition is NLSM, which causes only the macro call statement to be listed, with no expansion. These pseudo-operations remain in effect until a new macro listing control pseudo-operation is specified. | CD | L | ADR | F | X | N | Z | | |-----|----------|-------|---|-----------------------------------|--------|------------|-------------------------| | 1 2 | 3 | 4 — 6 | 7 | 8 | 9 | 10 | 111 | | Bit | Na | me | | N | Ieani | ng | | | 1 | C | | | C | arry | Bit | | | 2 | D | | | P | recisi | ion; ( | 0=Single; 1=Double | | 3 | L | | | C | arry | out c | of most significant bit | | 4-6 | AD | R | | A | ddre | ssing | g Mode | | | | | | | 00=1 | 6S | | | | | | | | 01=3 | 2 <b>S</b> | | | | | | | | 011= | 32R | | | | | | | | 010= | 64R | | | | | | | | 110= | 64V | | | 7 | F | | | 0=Floating point exception faults | | | | | 8 | X | | | 1=Integer exception faults | | | | | 9 | 9 N | | | Negative result | | | | | 10 | $Z^{-1}$ | | | Zero result | | | | #### PROCEED [address] [a-reg] [b-reg] [x-reg] [keys] Continue execution from breakpoint. Removes the current breakpoint if there is one, optionally sets a new breakpoint at address, and does a RUN command to the current program counter address. a-reg, b-reg, x-reg and keys have the same meaning as in the RUN command. #### QUIT Returns to the PRIMOS operating system. In SEG's VPSD returns to SEG command level. #### RELOCATE value Sets a new value for the access-mode relocation counter. #### RUN [start-add] [a-reg] [b-reg] [x-reg] [keys] Runs the executable program starting at **start-add** location. Prior to program entry, **a-reg**, **b-reg**, **x-reg**, and **keys** are optionally loaded. Control does not return to the debugging utility unless a breakpoint is encountered. In VPSD, use SN to specify the segment in which to run; start-add is just the 16-bit word number. #### SB seg-no word-no Loads the stack base register with a segment number (seg-no) and a word number (word-no). #### SEARCH block-start block-end match-word [mask] Searches memory from **block-start** to **block-end** for words equal to **match-word** under an optional 16-bit **mask**. # DEBUGGING UTILITIES # Introduction to TAP, PSD and VPSD Prime supplies three interactive debugging programs: - TAP (Trace And Patch) for sectored addressing modes - PSD (Prime Symbolic Debugger) for sectored and relative addressing modes - VPSD (Virtual Symbolic Debugger) for sectored, relative and virtual addressing modes. TAP is a small (one sector), octal format routine that examines, dumps and patches user programs. It has a breakpoint capability and can trace 16S and 32S instruction execution. PSD is a symbolic routine that can handle all of the PRIME-300 addressing modes. In addition to the functions provided by TAP (except EXECUTE and PATCH) it has enhanced functionality and additional input/output formats. VPSD is a symbolic routine that can handle the segmented addressing modes, as well as all of the PRIME-300 addressing modes. The functionality (except for instruction tracing) is essentially the same as PSD. Table 18-1 gives a complete alphabetical listing of all debugging commands and the programs which use them. #### **USING TAP** Load the object program, using the PRIMOS commands LOAD or RESTORE, and then enter the command TAP. Since TAP is in user memory along with your program, be sure TAP has not overlaid part of your program. When ready, TAP prints the \$ prompt character and waits for you to type in TAP command strings. **Terminating long operations**: To terminate long operations such as DUMP, type CTRL P to return to PRIMOS command level. **Restarting**: Restart at 'XX000 where XX is the sector occupied by TAP. To determine this value, RESTORE TAP and do a PM command to print the starting location (see Section 7 for a complete description of the PM command). | Command | Meaning | TAP | PSD | VPSL | |------------|--------------------------------------------------------------------------------|-------|------|-----------| | ACCESS | Access and print or alter contents of memory word | YES | YES | YES | | BREAKPOINT | Insert up to 10 breakpoints in program (TAP | | | | | | permits only 1 breakpoint) | YES | YES | YES | | BR | Display contents of base registers | NO | NO | YES | | COPY | Copy block to block | YES | YES | YES | | DEFINE | Define local symbols | NO | YES | NO | | DUMP | Print contents of block (or, in PSD and VPSD, write contents to optional file) | YES | YES | YES | | EFFECTIVE | Search for effective address under mask | NO | YES | YES | | EXECUTE | Execute a subroutine | YES | NO | NO | | EXECUTE | Execute segmented program | NO | NO | YES | | FILL | Fill block with constant | YES | YES | YES | | GO | Proceed from breakpoint | NO | YES | NO | | JUMPTRACE | Trace JMP, JST, HLT instructions | YES | YES | NO | | KEYS | Update CPU status | NO | YES | YES | | LB | Load link base register | NO | NO | YES | | LIST | Print contents of address | YES | YES | YES | | Ĺ <b>S</b> | Load external symbols from map file and | | | | | | enter symbolic address mode | NO | YES | NO. | | MAP | Type out all symbols with their values | NO | YES | NO | | MODE | Address mode selection | NO | YES | YES | | MONITOR | Execute program, reporting any reference to the specified effective address | YES | YES | NO | | NOT-EQUAL | Not-equal search for constant under mask | YES | YES | YES | | OPEN | Open file for memory dump or symbols | NO | YES | YES | | PATCH | Patch object program | YES | NO | NO | | PRINT | Print parameters | NO | YES | YES | | PROCEED | Remove breakpoint and proceed | NO | YES | YES | | QUIT | Return to PRIMOS (or SEG if SEG's VPSD) | NO | YES | YES | | RELOCATE | Alter relocation constant | NO | YES | YES | | RUN | Run object program | YES | YES | YES | | SB | Load stack base register | NO | NO | YES | | SEARCH | Search memory block for constant under | | | | | | mask | YES | YES | YES | | SN | Set segment number | NO | NO | YES | | SYMBOL | Enable/disable use of symbols in address | NICS. | ¥200 | NICO | | | typeout | NO | YES | NO | | TRACE | Trace object program | YES | YES | NO<br>vec | | UPDATE | Update memory word | YES | YES | YES | | VERIFY | Compare contents of one block of memory with another | YES | YES | YES | | VERSION | Print PSD version and restart location | NO | YES | YES | | WHERE | List location and remaining repeat counts for | 110 | 1110 | 110 | | WILLIAM | all breakpoints | NO | YES | YES | | XB | Load temporary base register | NO | NO | YES | | XR | Load X register | NO | YES | YES | | YR | Load Y register | NO | NO | YES | | ZERO | Zero breakpoint location | NO | YES | YES | #### **USING PSD** Load the object program, using the PRIMOS commands LOAD or RESTORE, and then decide which of the three versions of PSD you need to use. Since PSD is resident in user memory with your program, you must take precautions to prevent your program from being overlaid. See Table 18-2 for the name, starting location and suggested usage of each version. None of the three versions is relocatable. When ready, PSD prints the S prompt character and waits for you to type in PSD command strings. **Terminating long operations**: To terminate long operations such as DUMP, type CTRL P to return to PRIMOS command level. **Restarting**: Restart at 'XXXXX where 'XXXXX is PSD's starting address. To determine this value, type a VERSION command to print the starting location. | Name | Location | Comments | |--------|-------------------------|---------------------------------------------------------| | PSD20 | 20000 | Use when your system is small. i.e., 16k | | HPSD | 150000 | Use when your program is so large that it overlays PSD | | PSD | `60000 | Normal use | | VPSD | '60000 of segment '4000 | Normal use | | VPSD16 | 160000 | Use when your program is so large that it overlays VPSD | #### USING VPSD There are two versions of VPSD: stand-alone VPSD and SEG's VPSD. Both reside in segment '4000. There are three ways to enter VPSD, each of which has slightly different consequences for debugging: #### Action - 1. Load the object file using SEG's loader. Then return to "#" level with the "RE" command and issue the SEG command PSD. Obtain the starting address of SEG's VPSD with the VERSION command. Memory may now be examined and breakpoints set. Type "EX" to start the program. If it crashes, issue the PRIMOS level PM command to obtain the data at crash time. Then issue the PRIMOS command START using SEG's VPSD starting address. - 2. Load the runfile and enter VPSD via the "SEG filename 1/1" command. - 3. Load and execute the runfile using SEG. When the program crashes, use the PRIMOS command VPSD to call the stand-alone version of VPSD. #### Usage/Consequence Used when no runfile exists. When EXECUTE is given, the registers are as SEG initialized them. Preserves the entire program contents exactly as it was at the time of the crash, except for the program counter whose value you obtain via the PM command. Used when runfile exists. When EXECUTE is given, the registers are as SEG initialized them. Use only if SEG's VPSD has been destroyed. The registers are not preserved. #### **COMMAND LINE FORMAT** Each command is a one or two letter operation followed by one or more operands. Separators may be spaces or commas, and values may be omitted by including extra commas. Commands may be terminated by a carriage return or a semicolon. The ACCESS command differs from the others in that it remains in control and allows you to examine and/or alter more than one location without returning to command mode (signalled by the prompt character). The next location to be accessed is selected by the terminator used. (See ACCESS for details.) A question mark (?) may be used to abort a command string and return to command mode. If more than five octal digits are entered, only the last 16 bits are used. In TAP, if the wrong function code letter is entered, simply follow it with the correct character. (Only the last input letter of the command field is interpreted.) To cancel an incorrect parameter, type an asterisk (\*). #### Effective address formation (PSD and VPSD only) PSD processes input and output in all Prime-300 addressing modes: VPSD, in all Prime 350 and up addressing modes the mode is set by the MODE command. When the index register is needed, the current value of the X register is used: VPSD may use the Y register where appropriate and so specified. When either VPSD or PSD prints an address, it applies the same address formation process as the hardware, using the current values of the registers. For relative addresses, the access-mode current location counter is used as the value of the P register. #### Relocation constant (PSD and VPSD only) PSD can process addresses in a relocatable mode (equivalent to assembler REL) by maintaining a relocation constant which points to the start of a module. All addresses that are preceded by > are relative to this relocation constant. For a relocation constant of '3121. both \$A>0 and \$A '3121 would open location '3121. The relocation constant is set by the RELOCATE command. Setting the relocation constant to 0 disables this mode. For all output, any address which is larger than the relocation address is printed as > n, where n is the address minus the relocation address. Setting relocation constant=0 disables symbolic I/O as does SY 0. #### Input/output formats (PSD and VPSD only) While the default command line scan is octal, PSD and VPSD can accept input parameters and print output values in several different formats. The format is established by typing a colon followed by a single format letter. All input to the right of that format specifier is interpreted in that format until you type a new format specifier or a terminator. Format specifiers control the input for just the current line but have a global effect on output until you type a new format specifier. Table 18-3 describes the format specifiers. The following example illustrates their effects. Fill and Dump Example: F 100 200 :HAFAF Fills octal locations 100 to 200 with hexadecimal digits AFAF D 120 130 The typeout on the terminal will be in hexadecimal. **Symbolic instruction format**: enables user to use standard PMA symbolic instruction format for output and access mode input. The only restrictions are: - 1. Expressions only + and operations - 2. No literals - 3. Symbol use global symbols if the LS procedure has been used and any symbols defined within PSD - 4. Input is only legal in access mode, i.e., "S 100 200 :SAIA" is not legal - 5. The suffixes "+ 1C" and "+ nB" may be used to indicate character and bit offsets in VPSD | Format<br>ASCII | Code<br>:A | Input Two characters accepted first may not be:>= @ % , .NL / ? + -: * () or blank Second is required and may not be: / ? .NL. Note—to input ASCII characters in any format use 'CC (single quote followed by two characters) | Output Two characters are printed. An @ is sub- stituted for a nonprint- ing character | | |-----------------|------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------------------------------------------------------------------------------|--| | Binary | :B | Takes a sequence of 16 1's and 0's | Prints a sequence of sixteen 1's and 0's | | | Decimal | :D | Accepts up to five decimal (0-9) digits | Prints decimal digits | | | Hexadecimal | :Н | Accepts up to four hexadecimal (o-9, A, B, D, C, E, F) digits | Prints hexadecimal digits | | | Octal | :0 | Accepts up to six octal (o-7) digits | Prints octal digits | | | Symbolic | <b>:S</b> | Symbolic instructions (See below) | Symbolic instructions | | | AP * | :P | Symbolic instructions | Prints address pointers | | | Long * | :L | Accepts 32 bit octal integers | Prints 32 bit octal integers | | #### Command line operands These may be constants, constant expressions, or symbols. The format of a constant is: [: format] [>] $$\begin{cases} \pm digits \\ ASCII-constant \end{cases}$$ [:format] where: format format specifier (see Table 18-3) > relocatable mode ASCII-constant two letter constant in format described in Table 18-3 decimal, octal, binary or hexadecimal, depending on which format is in control The format of a constant expression is: constant [± constant] #### Current location pointer (PSD and VPSD) In access mode, a current location pointer is maintained, starting with the value of the start-address parameter of the ACCESS command. The location pointer determines the next location to be accessed. During each access operation, PSD replaces the value in the open location with the new value (if specified) and uses the line terminator to compute the next value of the current location pointer. For the comma or CR line terminators, the pointer is incremented after each access. Other line terminators provide different options. # TAP command summary #### TAP COMMAND SUMMARY Enter rust colored letters in upper-case only. #### ACCESS address Accesses a word in memory. The debugging program types the address and its contents and then waits for keyboard input in the following form: [value] terminator, where value is an octal number which replaces the contents of the accessed location, and terminator is one of the characters shown in Table 19-1. | Terminator | Function | |------------|-------------------------------------------------------------------------------------------------------------------| | CR | Alters contents of current location (if a value is given), moves to current location +1, and prints its contents. | | or 1 | Alters contents of current location (if a value is given), moves to current location -1, and prints its contents. | | / or ? | Exits from access mode. Does not close current location. | #### BREAKPOINT location Sets a breakpoint at the specified **location**. If the program is later executed and control reaches the breakpoint location, the debugging program prints CPU status and awaits further commands. One breakpoint is permitted. The actual breakpoint jump is placed in the object program only at execution time, and is removed after each use, however, the breakpoint address is retained for reuse. To remove the breakpoint completely, key in B'17(CR). #### COPY source-start source-end target Copies a block of memory from **source-start** to **source-end** into a new block of memory starting at **target**. If the target location lies between source start and source end, the non-overlapped portion is propagated through the target area. The size of the target area is always equal to the size of the source. If source-end equals source-start, the contents of location source-start will be copied into target. #### DUMP block-start block-end Prints the contents of the block of memory at locations **block-start** through **block-end** on the user terminal. The output format is eight octal words per line, preceded by the octal address of the first word on the line. Repetitious words and lines are suppressed as follows: - 1. If the remainder of the current line is identical to the word last printed, the line is terminated. - 2. If one or more subsequent lines are identical to the word last printed, the terminal skips one line. #### EXECUTE sub-name [a-reg] [b-reg] [x-reg] [keys] Executes a subroutine by branching to location **sub-name**. The A, B, and X registers and the keys (see Table 19-2) may be changed prior to executing the subroutine. The subroutine return should be via an indirect jump through its entry point, incremented by 0, 1 or 2, depending on the number of arguments, if any. Upon return from the subroutine, the 'TRACE' program prints the register contents as noted under RUN except that one or two meaningless words may precede the specified format to indicate that the subroutine has incremented its return link by 1 or 2. #### FILL block-start block-end constant Fills the memory block from block-start to block-end with the specified octal constant. If block-end does not exceed block-start, only the first location is filled. FILL is useful to test data area usage by pre-filling it with a visual pattern. #### JUMPTRACE [start-add] [a-reg] [b-reg] Traces the execution of the object program starting with **start-add** (default is current location). You may set the A register and B registers. JUMPTRACE, which is very useful for control-flow tracing, produces a diagnostic printout in the following format prior to the execution of any JMP, JST or HLT instruction: Location: instruction A= B= X= K= R= Any typed character will stop the trace. SVC's are not included in the trace. #### LIST address Prints the contents of address. Unlike ACCESS, LIST does not transfer the pointer to that location, a useful feature when you wish to examine a location without going there. #### MONITOR [start-add] [a-reg] [b-reg] address Traces the object program from **start-add** (default is current location) to **address**. You may set the A and B registers. If a memory reference instruction whose effective address equals address is encountered, data in trace format is printed on the terminal prior to the execution of that instruction. MONITOR answers the question "Where is the address being clobbered?" Typing any character will stop the trace after several more lines. The character typed is considered part of the next command, so a space is the usual choice. #### NOT-EQUAL block-start block-end n-match [mask] Searches memory between **block-start** and **block-end** for words not equal to **n-match** under an optional 16-bit **mask**. The masking function is a 16-bit logical AND. If no mask is specified, the entire word is tested. When a non-match is found, the address and its contents are typed out and the search continues to block-end. #### PATCH patch-loc branch-loc Inserts a patch in the object program. The instruction at **branch-loc** is replaced by a jump to **patch-loc**. The previous branch-loc instruction is inserted at patch-loc and the ACCESS subprocessor is entered with the current location set to patch-loc. You may now enter the patch, including a suitable return. Patch-loc must either be in the same sector as branch-loc or in Sector 0. #### RUN [start-add] [a-reg] [b-reg] [x-reg] [keys] Runs the executable program starting at start-add location. Prior to program entry, a-reg, b-reg, x-reg and keys are optionally loaded. Control does not return to the debugging utility unless a breakpoint is encountered. #### SEARCH block-start block-end match-word [mask] Searches memory from **block-start** to **block-end** for words equal to **match-word** under an optional 16-bit **mask**. If a mask is not specified, the entire word is tested. When a match is found, the address and its contents are typed out, and the search continues until location block-end has been tested. # Dynamically traces executable program starting at **start-add** with **a-reg** and **b-reg** optionally preset and prints a diagnostic printout prior to the interpretive execution of each object instruction. The printout, defaults, and halt mechanism are described in the JUMPTRACE command. When **p-val** is specified, the printout occurs only when the program counter equals p-val. If p-val is followed by 0, printout occurs the first time program counter equals p-val and every instruction thereafter. When **-1** interval is specified, printout occurs every interval instructions. HLT instructions always cause a printout followed by a return to command mode. #### ► UPDATE location contents Puts contents into location and prints the old and new contents of location. #### VERIFY source-start source-end copy-start Verify memory block at locations source-start to source-end against a copy starting at copystart. The program types the address and content of each location in the block which does not match the corresponding word in the copy. # PSD command summary ### **PSD COMMAND SUMMARY** Enter rust colored letters in upper-case only. # ACCESS address Accesses a word in memory. The debugging program types the **address** and its contents and then waits for keyboard input in the following form: ### [:format-symbol] [value] [:new-format] terminator where :format-symbol is one of the optional input/output format symbols (see Table 18-3). The new format takes effect immediately. For example :HAF enters the hexadecimal value AF, regardless of the previous input/output mode. value replaces the contents of the accessed location. The format is the current input/output format. The :new-format symbol is one of the optional input/output format symbols (see Table 18-3). The new format takes effect immediately upon all subsequent output until a new format symbol is entered. terminates is one of the characters shown in Table 20-1. Long instructions are input and printed in the assembler format, e.g., LDA % 2000. | Terminator | Function | |-----------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | CR | Alters contents of current location (if a value is given), move current location +1 and prints its contents. | | | Alters contents of current location (if a value is given), move current location -1 and prints its contents. | | / or ? | Exits from access mode. Does not close current location. | | .n(CR) | Moves to current location +n and prints its contents (n is octa- | | n(CR) | Moves to current location -n and prints its contents (n is octa | | <b>@</b> | For memory reference instructions of the form "INST* locationly. Saves a return address (current location +1), moves to effective address location, and prints its contents. Subsequaccesses (terminated by CR, comma, or) are relative to effective address. A\returns to the return address. Goes to effective address without indirection, but saves currently. | | | location as return address. | | $Z_{\rm const}$ | Returns to the return address saved by the last @. | | <b>)</b> | Returns to the return address saved by the last (. | | | For memory reference instructions only; calculates and prints effective address and its contents. No change is made to current location or its contents. | | | Close a location, setting it to a new value if one was supplied, return to command mode. | # **▶** BREAKPOINT location Sets a breakpoint at the specified **location**. If the program is later executed and control reaches the breakpoint location, the debugging program prints CPU status and awaits further commands. Up to ten breakpoints may be inserted. The GO command allows you to continue, leaving the breakpoint set. # COPY source-start source-end target Copies the block of memory from **source-start** to **source-end** into a new block of memory at **target**. If the target location lies between source start and source end, the non overlapped portion is propagated through the target area. The size of the target area is always equal to the size of the source. ### Example: | F 1000 | 1010 | :HFFFF | Fill locations 1000–1010 with hex FFFF | |--------|------|--------|--------------------------------------------| | F 1011 | 1020 | :HAAAA | Fill locations 1011–1020 with hex AAAA | | D 1000 | 1020 | | Display locations 1000–1020 | | C 1010 | 1016 | 1012 | Propagate alternate words of FFFF and AAAA | | D 1000 | 1020 | | Display locations 1000–1020 | # **▶** DEFINE symbol value Defines a **symbol**. The **value** may be a constant or a constant expression. If the symbol has already been defined, it is given the new value. ### Examples: | DE FOO 1000 | FOO = OCTAL 1000 | |--------------|------------------------| | RE 1000 | SET RELOCATION COUNTER | | DE FOO >3 | FOO = OCTAL 1003 | | DE FOO :AXX | FOO = 'XX' | | DE FOO: HF-A | FOO = 5 | | DE FOO :D>10 | FOO = OCTAL 1012 | ### Not allowed: | DE BAR FOO | SYMBOLS NOT PERMITTED AS VALUES | |---------------|-------------------------------------------| | DE FOO (1+>3) | NO PARENTHESES | | DE FOO >:HF | BAD SYNTAX. SHOULD BE :H>F | | DE FOO :AX | MUST HAVE TWO CHARACTERS AFTER :A | | DE FOO :A X | FIRST CHARACTER AFTER :A MUST BE 0-9, A-Z | | DE FOO :SLT | :S IS AN OUTPUT SPECIFIER ONLY | # DUMP block-start block-end [words-per-line] Prints the contents of the block of memory at locations block-start through Block-end on the use terminal or, optionall, in an external file. Words-per-line is number of words to be printed per line. The defaults is eight. You must open a file before dumping to it. If there are several files open, DUMP will use the last one opened. Close the dump file before ending your session. If you have used PSD to open a file for a program use and you wish to dump to a terminal, issue an OPEN command with no parameters prior to issuing the DUMP command. The default output format is eight octal words per line, preceded by the octal address of the first word on the line. Repetitious words are suppressed unless the number of words-per-line parameter only is specified. ### Example: O DMPFIL 1 2 D 1000 2000 0 0 1 4 # EFFECTIVE block-start block-end address [mask] Searches for an instruction with the specified effective address in the block from block-start to block-end, under an optional 16-bit mask. If no mask is specified, the entire address is tested. When a match is found, the instruction and its address are printed at the user terminal. The search continues until location blockend has been tested. Mask is a 16-bit word which may be expressed in any of the legal formats. EFFECTIVE is useful in finding locations where a particular location is referenced. The current value of the X register is used in the calculation. Instructions are interpreted in the current address/instruction mode as set by the MODE command and shown in the keys by the PRINT command. # FILL block-start block-end constant :format Fills the block of memory locations **block-start** through **block-end** with the specified **constant**. If block-end does not exceed block-start only the first location is filled. :**format** must be specified if you do not want the octal default. Specifying a format changes subsequent output formats. FILL is useful to test data area usage bypre-filling it with a visual pattern. ### Example: F 1000 1007 :HFFFF D 1000 1007 1000 FFFF # GO [count] [a-reg] [b-reg] [x-reg] [keys] Proceed from the current breakpoint, first executing the instruction at the breakpoint location. **count** is number of times to execute instruction at breakpoint location before breakpoint is taken. Default is one. The A, B and X registers and the keys may be preset (see Table 20-3). A count may be overidden by resetting a breakpoint. # JUMPTRACE [start-add] [a-reg] [b-reg] Traces the execution of the object program from **start-add**. The default is current location. The A and B registers may be present; the default is old value. JUMPTRACE, which is very useful for control-flow tracing, produces a diagnostic printout in the following format prior to the execution of any JMP, JST or HLT instruction: # Location: instruction A= B=X= K= R= Any typed character will stop the trace. SVC's are not included in the trace. ### KEYS value Sets CPU status keys to the specified octal value. The bit assignments vary depending on which mode you are in. ### ► LIST address Prints the contents of address in the current output format. Unlike ACCESS, LIST does not transfer the pointer to that location, a useful feature when you wish to examine a location without going there. # LS Enables the usage of external symbolic references during instruction typein and typeout. To use the load map symbols: - 1. Load the program and make a symbol file. - 2. Restore the user program, invoke PSD and load the converted file. The LS command puts PSD into symbolic mode. All addresses are typed as an offset from the nearest external symbol. Once the load map is prepared in this manner, you can enable or disable symbol interpretation with the SYMBOL command. ### Example: | OK, LOAD | CALL THE LOADER | |--------------------|-----------------------------------------| | GO | | | \$ LOAD B_PROG | LOAD THE PMA BINARY OBJECT PROGRAM | | LOAD COMPLETE | | | \$ SAVE \$PROG | SAVE THE RUNFILE | | \$ MAP LSYM 10 | CREATE A SYMBOL FILE LSYM | | \$ QUIT | | | OK, RESTORE \$PROG | GET PROGRAM | | OK, PSD | GET PSD | | GO | | | \$ 0 LSYM 1 1 | OPEN SYMBOL FILE ON FUNIT 1 FOR READING | | \$ LS | LOAD SYMBOLS | | \$ O Ø14 | CLOSE FUNIT 1 | | | | # ► MA Types the symbols and their definitions. $$MO & \begin{cases} D16S \\ D32S \\ D32R \\ D64R \end{cases}$$ D16S means use 16S address mode; D32S, use 32S address mode; D32R, use 32R address mode; and D64R, use 64R address mode. Controls how effective addresses are interpreted by setting the address mode bits of the CPU status keys. See KEYS for a full discussion of the CPU status keys. Other status bits are unaffected. MODE is a fast symbolic way of setting just the address mode, when you don't care about the other CPU status key bits. # MONITOR [start-add] [a-reg] [b-reg] address Traces the object program from **start-add** (the default is the current location) looking for **address.** You may print the A and B registers. If a memory reference instruction whose effective address equals address is encountered, data in trace format is printed on the terminal prior to the execution of that instruction. MONITOR answers the question "Where is the address being clobbered?" Typing any character will stop the trace after several more lines. The character typed is considered part of the next command, so a space is the usual choice. # NOT-EQUAL block-start block-end n-match [mask] Searches memory between **block-start** and **block-end** for words not equal to **n-match** under an optional 16-bit **mask**. The masking function is a 16-bit logical AND. If no mask is specified, the entire word is tested. When a non-match is found, the address and its contents are typed out and the search continues to block-end. # OPEN file name file-unit key Opens **file name** on **file-unit** to be used either as a DUMP output file or symbol table input file. **key** may be 1 (open for reading), 2 (open for writing), 3 (open for reading and writing), 4 (close). The parameters are the same as for the PRIMOS OPEN command. # PRINT Prints CPU/PSD parameters in octal as follows: prgctr: breakpoint a-reg b-reg x-reg keys relcon prgctr Program counter at the time of breakpoint relcon Current value of the access mode relocation constant # PROCEED [address] [a-reg] [b-reg] [x-reg] [keys] Continue execution from breakpoint. Removes the current breakpoint if there is one, optionally sets a new breakpoint at **address**, and does a RUN command to the current program counter address. **a-reg**, **b-reg**, **x-reg** and **keys** have the same meaning as in the RUN command. # QUIT Returns to the PRIMOS operating system. ### ► RELOCATE value Sets a new value for the access-mode relocation counter. # RUN [start-add] [a-reg] [b-reg] [x-reg[ [keys] Runs the executable program starting at **start-add** location. Prior to program entry. **a-reg**, **b-reg**, **x-reg**, and **keys** are optionally loaded. Control does not return to the debugging utility unless a breakpoint is encountered. # SEARCH block-start block-end match-word [mask] Searches memory from block-start to block-end for words equal to match-word under an optional 16-bit mask. If a mask is not specified, the entire word is tested. When a match is found, the address and its contents are typed out, and the search continues until location block-end has been tested. # Controls the use of symbols in address typeout: 1 means turn on symbol typeout; 0, turn off symbol typeout. # TRACE [start-add] [a-reg] [b-reg] {P-val [0] } Dynamically traces executable program starting at **start-add** with **a-reg** and **b-reg** optionally preset. A diagnostic printout is produced prior to the interpretive execution of each object instruction. The printout, defaults, and halt mechanism are described in the JUMPTRACE command. When **p-val** is specified, the printout occurs only when the program counter equals p-val. If p-val is followed by 0, printout occurs the first time program counter equals p-val and every instruction thereafter. When -1 interval is specified, printout occurs every interval instructions. HLT instructions always cause a printout followed by a return to command mode. ### UPDATE location contents Puts contents into location and prints the old and new contents of a location. # VERIFY block-start block-end copy Verifies memory from block-start through block-end against a copy starting at copy. The program types the address and content of each location which does not match the corresponding word in copy. The format of a VERIFY printout is: ### location block-contents copy-contents ### VERSION Prints the version number and restart address of the PSD you are using. If your program gets into a loop or dies after a RUN command, you can issue a PR or GO command, starting at this restart address. This causes pseudo breakpoint, saving the registers and entering PSD. Only the program counter register value will be lost, and even this may be found by issuing a PRIMOS P command prior to restarting PSD. # WHERE Lists all currently installed breakpoints and their remaining proceed counts. A proceed count of one is not listed. ### XREGISTER value Loads the X register with **value**—for example, before executing a RUN command or doing an effective address calculation. # ZERO [location] Removes the breakpoint at the specified location. If location is omitted, Z removes the breakpoint at the current program counter location. (P will show the current location.) Enter rust colored letters in upper case only. ### ACCESS address Accesses a word in memory. The debugging program types the **address** and its contents and then waits for the keyboard input in the following form: ### [:format-symbol] [value] [:new-format] terminator where **:format-symbol** is one of the optional input/output format symbols (see Table 18-3). The new format takes effect immediately. For example, :HAF enters the hexadecimal value AF, regardless of the previous input/output mode. **value** replaces the contents of the access location. The format is the current input/output format. The **:new-format** symbol is one of the optional input/output format symbols (see Table 18-3). The new format takes effect *immediately* upon all subsequent output until a new format symbol is entered. **terminator** is one of the characters shown in Table 21-1. Long instructions are input and printed in the same way as the assembler, e.g., LDA % 2000. | Terminator | Function | |------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | CR | Alters contents of current location (if a value is given), moves to current location +1 and prints its contents. | | | Alters contents of current location (if a value is given), moves to current location -1 and prints its contents. | | / or ? | Exits from access mode. Does not close current location. | | .n(CR) | Moves to current location +n and prints its contents (n is octal). | | n(CR) | Moves to current location -n and prints its contents (n is octal). | | <b>@</b> | For memory reference instructions of the form "INST* location" only. Saves a return address (current location +1), moves to the effective address location, and prints its contents. Subsequent accesses (terminated by CR, comma, ,. or) are relative to the effective address. A \ returns to the return address. | | ( | Goes to effective address without indirection, but saves current location as return address. | | \ | Returns to the return address saved by the last @. | | ) | Returns to the return address saved by the last (. | | = | For memory reference instructions only; calculates and prints the effective address and its contents. No change is made to the current location or its contents. If the instruction references a register, the contents of the register are printed. | ### **▶** BREAKPOINT location Sets a breakpoint at the specified **location**. If the program is later executed and control reaches the breakpoint location, the debugging program prints CPU status and awaits further commands. Up to ten breakpoints may be inserted. ### BREGISTER Prints the contents of the procedue base, stack base, link base and temporary base registers. # COPY source-start source-end target Copies the block of memory from **source-start** to **source-end** into a new block of memory at **target**. If the target location lies between source start and source end, the non-overlapped portion is propagated through the target area. The size of the target area is always equal to the size of the source. Example: | F 1000 | 1010 | :HFFFF | Fill locations 1000–1010 with HEX FFFF | |--------|------|--------|--------------------------------------------| | F 1011 | 1020 | :HAAAA | Fill locations 1011–1020 with HEX AAAA | | D 1000 | 1020 | | Display locations 1000–1020 | | C 1010 | 1016 | 1012 | Propagate alternate words of FFFF and AAAA | | D 1000 | 1020 | | Display locations 1000–1020 | # DUMP block-start block-end [words-per-line] Prints the contents of the block of memory at locations **block-start** through **block-end** on the user terminal or optionally in an external file. **words-per-line** number of words to be printed per line. The default is eight. You must open a file before dumping to it. If there are several files open, DUMP will use the last one opened. Close the dump file before ending your session. If you have used VPSD to open a file for program use and you wish to dump to a terminal, issue an OPEN command with no parameters prior to issuing the DUMP command. The default output format is eight octal words per line, preceded by the octal address of the first word on the line. Repetitious words are suppressed unless the number of words-per-line parameter is specified. Example: ``` O DMPFIL 1 2 D 1000 2000 0 0 1 4 ``` # ► EFFECTIVE block-start block-end address [mask] Searches for an instruction with the specified effective address in the block from block-start to block-end, under an optional 16-bit mask. If no mask is specified, the entire address is tested. When a match is found, the instruction and its address are printed at the user terminal. The search continues until location blockend has been tested. Mask is a 16-bit word which may be expressed in any of the legal formats. EFFECTIVE is useful in finding locations where a particular location is referenced. The current values of the X and Y registers are used in the calculation. Instructions are interpreted in the current address/instruction mode as set by the MODE command and shown in the keys by the PRINT command. # EXECUTE Begins execution of a segmented program by passing control to SEG. SEG sets the initial register values; any other value at the time EX is issued is lost. # FILL block-start block-end constant :format Fills the block of memory locations block-start through block-end with the specified constant. If block-end does not exceed block-start only the first location is filled. :format must be specified if you do not want the octal default. Specifying a format changes subsequent output formats. FILL is useful to test data area usage by pre-filling it with a visual pattern. ### Example: F 1000 1007 :HFFFF D 1000 1007 4001/1000 FFFF # FA regno Accesses field address register **regno**. New values may be entered to replace old ones. Carriage return advances to the "next" register, and " "(" will switch to access mode and display the location referenced by the field address register in ASCII. A ")" will return to "FA" mode. # FL regno Accesses field length register **regno**. New values may be entered to replace old ones. Carriage return advances to the "next" register and " # KEYS value Sets CPU status keys to the specified octal **value**. The assignments vary depending on which mode you are in. See tables 21-2 and 21-3. # LB seg-no word-no Loads the link base register with a segment number (seg-no) and word number (word-no). ## LIST address Prints the contents of address in the current output format. Unlike ACCESS, LIST does not transfer the pointer to that location, a very useful feature when you wish to examine a location without going there. **D16S** Means use 16S address mode; **D32S**, use 32S address mode; **D32R**, use 32R address mode; **D64R**, use 64R address mode; and **D64V**, use 64V address mode. Controls how effective addresses are interpreted by setting the address mode bits of the CPU status keys. See KEYS for a full discussion of the CPU status keys. Other status bits are unaffected. MODE is a fast symbolic way of setting just the address mode, when you don't care about the other CPU status key bits. D64V prints the segment and word number for all addresses (initial segment number is '4000) and interprets instructions as the Prime 400 hardware does. Base register references for all long instructions are printed as PB%, SB%, LB%, or XB%. Short instructions which reference SB or LB print SB or LB as part of the address. # NOT-EQUAL block-start block-end n-match [mask] Searches memory between **block-start** and **block-end** for words not equal to **n-match** under an optional 16-bit **mask**. The masking function is a 16-bit logical AND. If no mask is specified, the entire word is tested. When a non-match is found, the address and its contents are typed out and the search continues to block-end. # OPEN file name file-unit key Opens file name on file-unit to be used either as a DUMP output file or symbol table input file. **Key** may be: 1 (open for reading), 2 (open for writing), 3 (open for reading and writing) or 4 (close). The key parameters are the same as for the PRIMOS OPEN command. ### PRINT Prints CPU/PSD parameters in octal as follows: | prgctr | breakpoint a-reg b-reg x-reg keys relcon [y-reg is VPSD] | |--------|----------------------------------------------------------| | prgctr | The program counter at the time of breakpoint | | relcon | The current value of the access mode relocation | | С | D | | | ADR | | | | | | SHIFT COUNT | | | | | |---|------|-----|-----|-----|---------|---|----|------|------|-------------|------------------------------------------------------------|--|--|--| | 1 | 2 | 3 | 4 | 5 | | 6 | 7 | _ | 8 | 9 | _ 1 | | | | | | Bit | Nar | ne | | | | M | ean | ing | | | | | | | | 1 | C | | | | | Ca | arry | Bi | t | | | | | | | 2 | D | | | | | Pr | eci | sior | ı; O | =Single; 1=Double | | | | | | 3 | _ | | | | | N | ot u | sec | l | | | | | | | 4 | _ | | | | | N | ot u | sec | l | | | | | | | 5-6 | AD | R | | | | A | ddr | essi | ng | Mode | | | | | | | | | | | | | 00= | 168 | , | | | | | | | | | | | | | | 01= | 328 | 5 | | | | | | | | | | | | | | 11= | 32F | ₹ | | | | | | | | | | | | | | 10= | 64F | ₹ | | | | | | | 7 | _ | | | | | Ν | ot u | sec | l | | | | | | | 8 | - | | | | | Ν | ot u | sec | 1 | | | | | | | 9–16 | SH | IFT | CO | UN<br>· | Т | | | | | —low order 8 bits of the floating point exponent register. | | | | If a mask is not specified, the entire word is tested. When a match is found, the address and its contents are typed out, and the search continues until location block-end has been tested. # ► SN seg-no Use **seg-no** as the segment number for all commands where only a word number is entered, such as UPDATE, DUMP, etc. # UPDATE location contents Puts contents into location and prints the old and new contents of location. # VERIFY block-start block-end copy Verifies memory from **block-start** through **block-end** against a copy starting at **copy**. The program types the address and content of each location which does not match the corresponding word in copy. The format of a VERIFY printout is: ### location block-contents copy-contents # VERSION Prints the version number and restart address of the VPSD you are using. If your program goes into a loop or dies after a RUN command, you can issue a PR or GO command, starting at this restart address. This causes a pseudo-breakpoint, saving the registers and entering VPSD. Only the program counter register value will be lost, and even this may be found by issuing a PRIMOS P command prior to restarting VPSD. # WHERE Lists all currently installed breakpoints and their remaining proceed counts. A proceed count of one is not listed. # XB seg-no word-no Loads temporary base register with a segment number (seg-no) and word number (word-no. ### XREGISTER value Loads the X register with **value**—for example, before executing a RUN command or doing an effective address calculation. ### YREGISTER value Loads value into the Y index register. # ZERO [location] Removes the breakpoint at the specified location. If location is omitted, $\mathbf{Z}$ removes the breakpoint at the current program-counter location. (P will show the current location.) # Assembler attribute table # **APPENDICES** ## **ASSEMBLER ATTRIBUTES** A list of the current assembler attributes follows. For a complete discussion of the use and function of assembler attributes see section 17, Macro Facility. | Labe | l Number | Description | |------|--------------|-------------------------------------------| | | 0 | Number of arguments in current macro call | | | 1 | Current macro call number | | | 100 | A-register | | | 101 | B-register | | | 102 | X-register | | CC | 103 | Current character pointer | | CCM | 104 | Character count max of source line | | | 105 | Used by dynm (must precede cdyn) | | CDY | N 106 | Current dynamic storage pointer | | MDY | N 107 | Maximum dynamic stack space used | | | 108 | (spare) | | MCL | <b>S</b> 109 | Macro list control | | MCR | <b>C</b> 110 | Current extent of macro call number | | | 111 | (spare) | | MCR | N 112 | Current macro nest number | | MOD | E 113 | Current mode of assembler | | NCR | <b>D</b> 114 | Current record number (card number) | | NER | <b>R</b> 115 | Number of lines in program with errors | | NMF | L 116 | No-macro-search flag (0=search) | | PASS | 117 | Pass 1=0, pass 2=1 | | RPL | 118 | Current program counter value | | STAI | <b>(</b> 119 | Current temporary store stack limit | | TC | 120 | Last character fetched | | TCH | <b>B</b> 121 | TC held back flag | | TCN | <b>r</b> 122 | TC repeat count | | IFLG | 123 | Indirect operator flag (0=indirect) | | DFVI | L 124 | Table search value | | SEG | 125 | Seg mode flag (0, 1, -1) | | ABM | 126 | Current abstract machine | | | | 0=S,R and $1=V,I$ | | PMB | 127 | Procedure size max | | LBM | 128 | Link size max | # ASCII character set The standard character set used by Prime is the ANSI, ASCII 7-bit set. ### PRIME USAGE Prime hardware and software uses standard ASCII for communications with devices. The following points are particularly important to Prime usage. - Output Parity is normally transmitted as a zero (space) unless the device requires otherwise, in which case software will compute transmitted parity. Some controllers (e.g., MLC) may have hardware to assist in parity generations. - Input Parity is ignored by hardware and by standard software. Input drivers are responsible for making the parity bit suit the host software requirements. Some controllers (e.g., MLC) may assist in parity error detection. - The Prime internal standard for the parity bit is one, i.e., '200 is added to the octal value. ### KEYBOARD INPUT Non-printing characters may be entered into text with the logical escape character ^ and the octal value. The character is interpreted by output devices according to their hardware. Example: Typing '207 will enter one character into the text. | CTRL-P | ('220) | is interpreted as a .BREAK. | |--------|--------|------------------------------------------| | .CR. | ('215) | is interpreted as a newline (.NL.) | | ,, | ('242) | is interpreted as a character erase | | ? | ('277) | is interpreted as line kill | | \ | ('334) | is interpreted as a logical tab (Editor) | Table B-1. ASCII Character Set (Non-Printing) | Octal<br>Value | ASCII<br>Char | Comments/Prime Usage | Control<br>Char | |----------------|---------------|-----------------------------------------------|--------------------| | 200 | NULL | Null character – filler | ^ <b>@</b> | | 201 | SOH | Start of header (communications) | ^A | | 202 | STX | Start of text (communications) | <b>. 18</b> | | 203 | ETX | End of text (communications) | $\mathbf{\hat{C}}$ | | 204 | EOT | End of transmission (communications) | <b>D</b> | | 205 | ENQ | End of I.D. (communications) | <b>'E</b> | | 206 | ACK | Acknowledge affirmative (communications) | <b>`F</b> | | 207 | BEL | Audible alarm (bell) | <b>'</b> G | | 210 | BS | Back space on position (carriage control) | <b>'H</b> | | 211 | HT | Physical horizontal tab | 1 | | 212 | LF | Line feed; ignored as terminal input | J | | 213 | VT | Physical vertical tab (carriage control) | ^K | | 214 | FF | Form feed (carriage control) | L | | 215 | CR | Carriage return (carriage control) (1) | ^M | | 216 | SO | RRS-red ribbon shift | îN | | 217 | SI | BRS-black ribbon shift | O | | 220 | DLE | RCP-relative copy (2) | <b>P</b> | | 221 | DC1 | RHT-relative horizontal tab (3) | ^Q | | 222 | DC2 | HLF-half line feed forward (carriage control) | <b>^R</b> | | 223 | DC3 | RVT-relative vertical tab (4) | <b>^</b> S | | 224 | DC4 | HLR-half line feed reverse (carriage control) | <b>'T</b> | | 225 | NAK | Negative acknowledgement (communications) | `U | | 226 | SYN | Synchronocity (communications) | <b>^</b> V | | 227 | ETB | End of transmission block (communications) | `W | | 230 | CAN | Cancel | <b>`</b> X | | 231 | EM | End of Medium | ^ Y | | 232 | SUB | Substitute | <b>^</b> Z | | 233 | ESC | Escape | | | 234 | FS | File separator | | | 235 | GS | Group separator | 1 | | 236 | RS | Record separator | ^* | | 237 | US | Unit separator | | ### Notes - 1. Interpreted as .NL. at the terminal. - 2. .BREAK. at terminal. Relative copy in file; next byte specifies number of bytes to copy from corresponding position of preceding line. - 3. Next byte specifies number of spaces to insert. - 4. Next byte specifies number of lines to insert. ### Conforms to ANSI X3.4-1968 The parity bit ('200) has been added for Prime-usage. Non-printing characters (^c) can be entered at most terminals by typing the (control) key and the character key simultaneously. | 241 | Octal<br>Value | ASCII<br>Character | Octal<br>Value | ASCII<br>Character | Octal<br>Value | ASCII<br>Character | |-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------|--------------------|----------------|--------------------|----------------|---------------------------| | 241 | 240 | .SP. (1) | 300 | @ | 340 | `(9) | | 243 # (3) 303 C 343 c 244 \$ 304 D 344 d 245 %e 305 E 345 e 246 & 306 F 346 f 247 '(4) 307 G 347 g 250 ( 310 H 350 h 251 ) 311 I 351 i 252 * 312 J 352 j 253 + 312 K 353 k 254 ,(5) 314 L 354 l 255 - 315 M 355 m 256 . 316 N 356 n 257 / 317 O 357 o 260 0 320 P 360 p 261 1 321 Q 361 q 262 2 322 R 362 r | 241 | | | | 341 | | | 243 # (3) | 242 | "(2) | 302 | В | 342 | b | | 244 \$ 304 D 344 d 245 % 305 E 345 e 246 & 306 F 346 f 247 '(4) 307 G 347 g 250 ( 310 H 350 h 251 ) 311 I 351 i 252 * 312 J 352 j 253 + 312 K 353 k 254 .(5) 314 L 354 l 255 - 315 M 355 m 256 . 316 N 356 n 257 / 317 O 357 o 260 0 320 P 360 p 261 1 321 Q 361 q 262 2 322 R 362 r 263 3 3 323 S 363 s 264 4 324 T 364 t 265 5 325 U 365 u 266 6 326 V 366 v 267 7 327 W 367 w 270 8 330 X 370 x 271 9 331 Y 371 y 272 : 332 Z 372 Z 273 : 333 374 1 274 < 334 N 374 275 = 335 375 276 > 336 `(7) 376 ~(10) | 243 | | 303 | C | 343 | | | 246 & 306 F 346 f 247 '(4) 307 G 347 g 250 ( 310 H 350 h 251 ) 311 I 351 i 252 * 312 J 352 j 253 + 312 K 353 k 254 .(5) 314 L 354 l 255 - 315 M 355 m 256 . 316 N 356 n 257 / 317 O 357 o 260 0 320 P 360 p 261 1 321 Q 361 q 262 2 322 R 362 r 263 3 323 S 363 s 264 4 324 T 364 t 265 5 325 U 365 u 266 6 326 V 366 v 270 8 330 X 370 x 271 9 331 Y 371 y 272 : 332 Z 372 Z 273 : 333 373 274 < 334 N 374 275 = 335 375 276 > 336 ^(7) 376 ~ (10) | 244 | | 304 | D | 344 | $\mathbb{R}^{\mathbf{d}}$ | | 247 | 245 | % | 305 | | 345 | | | 250 | 246 | & | 306 | F | 346 | | | 250 | 247 | (4) | 307 | G | 347 | g | | $\begin{array}{cccccccccccccccccccccccccccccccccccc$ | 250 | ( | 310 | H | 350 | ĥ | | $\begin{array}{cccccccccccccccccccccccccccccccccccc$ | 251 | 3 | 311 | Ĭ | 351 | | | $\begin{array}{cccccccccccccccccccccccccccccccccccc$ | 252 | * | 312 | J | 352 | | | $\begin{array}{cccccccccccccccccccccccccccccccccccc$ | 253 | + 3 3 3 3 3 3 3 | 312 | K | 353 | | | $\begin{array}{cccccccccccccccccccccccccccccccccccc$ | 254 | , (5) | 314 | | 354 | 1 | | $\begin{array}{cccccccccccccccccccccccccccccccccccc$ | 255 | | 315 | | 355 | m | | $ \begin{array}{cccccccccccccccccccccccccccccccccccc$ | 256 | | | | | n | | $ \begin{array}{cccccccccccccccccccccccccccccccccccc$ | 257 | 1 | | | | 0 | | $ \begin{array}{cccccccccccccccccccccccccccccccccccc$ | 260 | 0 | | P | 360 | p | | 263 3 323 S 363 s 264 4 324 T 364 t 265 5 325 U 365 u 266 6 326 V 366 v 267 7 327 W 367 W 270 8 330 X 370 x 271 9 331 Y 371 y 272 : 332 Z 372 Z 273 : 333 373 374 274 < 334 \ 376 | 261 | | | Q | | q | | $ \begin{array}{cccccccccccccccccccccccccccccccccccc$ | 262 | 2 | | | | | | $ \begin{array}{cccccccccccccccccccccccccccccccccccc$ | 263 | 3 | 323 | | 363 | <b>S</b> | | $ \begin{array}{cccccccccccccccccccccccccccccccccccc$ | 264 | | | | | | | $ \begin{array}{cccccccccccccccccccccccccccccccccccc$ | | | | | | u | | $\begin{array}{cccccccccccccccccccccccccccccccccccc$ | | | | | | $\mathbf{v}$ | | $\begin{array}{cccccccccccccccccccccccccccccccccccc$ | | | | | | W | | $\begin{array}{cccccccccccccccccccccccccccccccccccc$ | 270 | | | | | X | | $\begin{array}{cccccccccccccccccccccccccccccccccccc$ | | 9 | | | | | | $\begin{array}{cccccccccccccccccccccccccccccccccccc$ | 272 | | | | | Z | | $\begin{array}{cccccccccccccccccccccccccccccccccccc$ | | | | 1 | | | | 276 > 336 ^ (7) 376 ~ (10) | | | | | | | | | | | | | | | | 277 ? (6) 337 <u>(8)</u> 377 DEL (11) | | | | | | | | | 277 | ? (6) | 337 | (8) | 377 | DEL (11) | - 1. Space forward one position - 2. Terminal usage erase previous character - 3. £ in British use - 4. Apostrophe/single quote - 5. Comma - 6. Terminal usage kill line - 7. 1963 standard †; terminal use logical escape - 8. 1963 standard ← - 9. Grave - 10. 1963 standard ESC - 11. Rubout ignored Conforms to ANSI X3.4-1968 1963 variances are noted The parity bit ('200) has been added for Prime usage. # Error messages ### INTRODUCTION Error messages are given in the following order: - 1. PMA Error Messages - 2. Loader Error Messages - 3. SEG Loader Error Messages - 4. Run-time Error Messages In each group errors are listed alphabetically. Run-time error messages beginning with a filename, device name, UFDname, etc., are alphabetized according to the first word which is constant. The user should have no trouble in determining this word (the second word in the message). Leading asterisks, etc., are ignored in alphabetizing. All run-time errors have been grouped together to facilitate lookup by the user. ### PMA ERROR MESSAGES | C00:<br>F00:<br>F01:<br>F02: | INSTRUCTION IMPROPERLY TERMINATED ILLEGAL TERMINATOR ON ARGUMENT # EXPRESSION UNRECOGNIZED OPERATOR IN EXPRESSION FAIL PSEUDO-OP ENCOUNTERED | |------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------| | F03: | OPERAND FIELD EMPTY; OPERAND REQUIRED | | G00: | GO-TO OR BACK-TO USED OUTSIDE OF MACRO OR ARGUMENT IS NOT SYMBOL | | G01: | END/ENDM PSEUDO-OP IS WITHIN GO-TO OR BACK-TO SKIP AREA | | I00: | TAG MODIFIER ILLEGAL ON GENERIC, I/O, OR SHIFT INSTRUCTION | | I01: | TAG MODIFIED NOT PERMITTED ON 32I MODE FIELD INSTRUCTION | | I03: | CAN'T MAKE THIS INSTRUCTION SHORT (#) | | I04: | ILLEGAL TAG MODIFIED FIELD ON 64V MODE LDX CLASS INSTRUCTION | | I05: | TAG MODIFIED NOT PERMITTED ON 64V MODE BRANCH INSTRUCTION | | I06: | ILLEGAL INDIRECT OR INDEX SPECIFICATION WITH COMMON/<br>EXTERNAL SYMBOL | | I07: | INDEX SPECIFIED INVALID WITH AP/IP PSEUDO-OP | | I08: | TAG MODIFIED FIELD NOT PERMITTED ON 32I MODE BRANCH | **INSTRUCTION** | L00: | IMPROPER LABEL (CONSTANT OR TERMINATOR IN LABEL FIELD) | | | | | | | |---------------|---------------------------------------------------------------------------------------------------------|--|--|--|--|--|--| | L01: | EXTERNALL VARIABLE DISALLOWED IN LITERAL | | | | | | | | L02: | ILLEGAL ARGUMENT IN EQU, SET, OR XSET | | | | | | | | M00: | SYMBOL MULTIPLY DEFINED | | | | | | | | N00: | 'END' STATEMENT ENCOUNTERED WITHIN MACRO OR IF | | | | | | | | O00: | UNRECOGNIZED OPCODE OR 32I-ONLY OPCODE IN NON-32I | | | | | | | | | MODE | | | | | | | | O01: | THIS MEMORY REFERENCE INSTRUCTION ONLY PERMITTED IN | | | | | | | | | 64V MODE | | | | | | | | O02: | THIS MEMORY REFERENCE INSTRUCTION ONLY PERMITTED IN | | | | | | | | | S/R MODE | | | | | | | | P00: | MISMATCHED PARENTHESIS | | | | | | | | Q00: | AP ONLY PERMITTED IN 64V/32I MODE | | | | | | | | Q01: | IP ONLY PERMITTED IN 64V/32I MODE | | | | | | | | Q02: | ENDM PSEUDO-OP DISALLOWED OUTSIDE OF MACRO DEFINI- | | | | | | | | Doo. | TION ARITHMETIC STACK OVERFLOW: REDUCE THE COMPLEXITY OF | | | | | | | | R00: | THE EXPRESSION AND TRY AGAIN | | | | | | | | R01: | MULTIPLY DEFINED MACRO OR MACRO NAME FIELD EMPTY | | | | | | | | S00: | INSTRUCTION REQUIRES DESCECTORIZATION ('LOAD' MODE) | | | | | | | | S00.<br>S01: | INDIRECT DAC DISALLOWED IN C64R MODE | | | | | | | | S02: | 64V INSTRUCTION DISALLOWED IN C64R MODE | | | | | | | | T00: | SYNTAX ERROR IN 32I MODE TAG MODIFIED FIELD | | | | | | | | U00: | UNDEFINED SYMBOL IN ADDRESS FIELD OR EXPRESSION | | | | | | | | U01: | UNDEFINED SYMBOL IN 6ORG' OR 6SETB' | | | | | | | | V01: | CONTENTS OF BIT FIELD OUT OF RANGE | | | | | | | | V02: | UNRECOGNIZED OPERATOR IN EXPRESSION | | | | | | | | V03: | FUNCTION CODE OR DEVICE ADDRESS OUT OF RANGE IN I/O | | | | | | | | | INSTRUCTION | | | | | | | | V04: | SHIFT COUNT OUT OF RANGE IN SHIFT INSTRUCTION | | | | | | | | V05: | NO COMMA FOLLOWS FAR SPECIFICATION IN FIELD ADDRESS | | | | | | | | • v | INSTRUCTION | | | | | | | | V06: | NO COMMA FOLLOWS REGISTER # IN 32I MODE REGISTER GENERIC | | | | | | | | 1707. | NERIC NO COMMA FOLLOWS REGISTER # IN 32I MODE FLOATING PT | | | | | | | | V07: | REGISTER GENERIC | | | | | | | | V08: | NO COMMA FOLLOWS REGISTER # IN 32I MODE BIT TEST IN- | | | | | | | | V 00. | STRUCTION | | | | | | | | V09: | NO COMMA FOLLOW BIT # IN 32I MODE BIT TEST INSTRUCTION | | | | | | | | V10: | BAD DELIMITER IN 32I MODE GENERAL REGISTER MEMORY | | | | | | | | | REFERENCE INSTRUCTION | | | | | | | | V11: | BAD DELIMITER IN 32I MODE SHIFT INSTRUCTION | | | | | | | | V12: | BAD SHIFT COUNT IN 32I MODE SHIFT INSTRUCTION | | | | | | | | V13: | ILLEGAL TAG MODIFIED FIELD FOR 32I MODE SHIFT INSTRUC- | | | | | | | | | TION | | | | | | | | V14: | BAD DELIMITER FOLLOWS REGISTER # IN 32I MODE PIO IN- | | | | | | | | ***- | STRUCTION | | | | | | | | V15: | LABEL REQUIRED ON DFTB/DFTV PSEUDO-OP | | | | | | | | V16: | OPEN PARENTHESIS MISSING ON DFTB/DFVT ARGUMENT | | | | | | | | V17: | CLOSE PARENTHESIS MISSING ON DFTB/DFVT ARGUMENT | | | | | | | | V18:<br>V19: | LABEL REQUIRED ON IFTF, IFTT, IFVT, IFVF PSEUDO-OP SYMBOL NOT FOUND IN IFTF, IFTT, IFVT, IFVF PSEUDO-OP | | | | | | | | V 19:<br>V20: | ABS/REL PSUEDO-OP ILLEGAL IN SEG/SEGR MODE | | | | | | | | V 4U: | VDOVINET LOUEDO-OL TEPERVE IN 9ER/9ERV MODE | | | | | | | | V21: | SEG/SEGR PSEUDO-OP SPECIFIED AFTER CODE HAS BEEN GENERATED | |--------------|-------------------------------------------------------------------------------------| | V22: | PROC/LINK SPECIFICATION ONLY ALLOWED IN SEG/SEGR | | | MODE | | V23: | FIELD OUT OF RANGE IN DDM PSEUDO-OP | | V24: | ILLEGAL ARGUMENT FOLLOWS 'EXT' PSEUDO-OP | | V25: | 'END' PSEUDO-OP ENCOUNTERED WITHIN MACRO | | V26: | SYNTAX ERROR IN DYMN PSEUDO-OP ARGUMENT(S) | | V27: | ILLEGAL ARGUMENT FOLLOWS SUBR/ENT PSEUDO-OP | | V28: | 16 BITS NOT DEFINED BY VFD PSEUDO-OP (UNDEFINED BITS SET TO 0) | | V29: | OPERAND MISSING OR UNRECOGNIZED OPERATOR IN EX- | | | PRESSION | | V30: | UNTERMINATED CHARACTER STRING | | V31: | VALUE OVERFLOW IN FLOATING POINT NORMALIZE | | V32: | VALUE OVERFLOW IN FLOATING POINT (RE-)NORMALIZE | | V33: | SIGNIFICANCE LOST IN SCALED BINARY DATUM | | V34: | FLOATING POINT VALUE OUT OF RANGE | | V35: | 'BCI' PSEUDO-OP REPEAT COUNT ERROR | | V36: | ILLEGAL SYMBOL TYPE IN 'BCI' REPEAT COUNT SPECIFICATION | | V37: | 'CALL' PSEUDO-OP FOLLOWED BY CONSTANT OR TERMINATOR | | V38: | BAD ADDRESS FIELD FOLLOWING 'COMN' PSEUDO-OP | | V39: | ILLEGAL REPEAT COUNT IN DATA DEFINITION PSEUDO-OP | | V40: | ILLEGAL ARGUMENT FOLLOW DEC/OCT PSEUDO-OP | | V41: | RLIT SPECIFIED AFTER CODE HAS BEEN GENERATED | | V42: | WCS ENTRANCE OUT OF RANGE—MUST BE 0-63 | | V43: | SYML NOT PERMITTED AFTER CODE HAS BEEN GENERATED | | V44: | SYML ONLY PERMITTED IN SEG/SEGR MODE | | X00: | 32I MODE REGISTER SPECIFICATION ERROR | | Y00: | PHASE ERROR—THE VALUE OF THE SYMBOL DEFINED ABOVE DIFFERS BETWEEN PASS 1 AND PASS 2 | | Z00: | ILLEGAL ABSOLUTE REFERENCE IN SEG/SEGR MODE | | Z01: | ABSOLUTE REFERENCE OUTSIDE OF 0-7 DISALLOWED IN SEG | | Z02: | ABSOLUTE REFERENCE IN AP/IP DISALLOWED | | Z03: | ONLY 1 EXTERNAL NAME IS ALLOWED WITHIN AN EXPRESSION | | Z04: | THE MODE ASSOCIATED WITH THE RESULT OF THE EXPRESSION | | | IS ILLEGAL WITH SPECIFIED INSTRUCTION | | Z05: | THE RESULTANT MODE OF THIS EXPRESSION IS ILLEGAL WHEN | | | USED WITH THE SPECIFIED OPCODE OR PSEUDO-OP | | Z06: | MORE THAN 1 OPERAND IS NON ABS/REL OR THE RIGHT-HAND | | • | OPERAND IS NON ABS/REL | | <b>Z07</b> : | AN EXTERNAL NAME IS NOT PERMITTED | | <b>Z08</b> : | NON-16-BIT INTEGER IS ILLEGAL IN AN EXPRESSION | | | | ### LOADER ERROR MESSAGES ### **ALREADY EXISTS!** An attempt is being made to define a new symbol; however, the symbol name is already a defined symbol in the symbol table. ## **BAD OBJECT FILE** The object text is not recognizable. This usually occurs when an attempt is made to load source code or when the object text was compiled or assembled for segmented loading. # C ### BASE SECTOR 0 FULL All locations in the sector zero base area have been used. Use the AU command to generate base areas at regular intervals, or use the SETB or LOAD commands to specifically place base areas. ### CAN'T DEFER COMMON, OLD OBJECT TEXT The Defer Common command has been given and a module created with a pre-Rev. 14 compiler or assembler has been encountered. It is not possible to defer Common in this case. The module must be recreated with a Rev. 15 or later compiler or assembler. ### CAN'T - PLEASE SAVE The EXecute command has been given for a run file which has required virtual loading. SAve the runfile and give the EXecute command. ### CM\$ Command line error. Unrecognized command given. Not fatal. ### COMMON OUT OF REACH COMMON above '100000 is out of reach of the current load mode (16S, 32S or 32R). Use the MOde command to set the load mode to 64R. ### COMMON TOO LARGE Definition of this COMMON block causes COMMON to wrap around through zero. Moving the top of COMMON – with the COMMON command – may help. ### sname ILLEGAL COMMON REDEFINITION An attempt is being made to redefine COMMON block **sname** to a longer length. The user's program should be examined for consistent COMMON definitions. At the very least the longest definition for a COMMON block should be first. ### XXXXXX MULTIPLE INDIRECT A module loading in 64R mode requires a second level of indirection at location **xxxxxx**. This message usually results when an attempt is made to load code compiled or assembled for 32R mode in 64R mode. It can also happen if code has accidentally been loaded into base areas as the result of a bad load command sequence. ### sname xxxxxx NEED SECTOR ZERO LINK At location **xxxxxx** a link is required for desectoring the instruction. No base areas are within reach except sector zero. The last referenced symbol was **sname**. This message is only generated when the SZ command has been given. Sname may be the name of a COMMON block, the name of the routine to which the link should be made, or the name of the module being loaded. # XXXXXX NO POST BASE AREA, OLD OBJECT TEXT A post base area has been specified for module which was created with a pre-Rev.14 compiler or assembler. No base area is created. Recreate the object text with a Rev. 15 or later compiler or assembler. This is not a fatal error. ### PROGRAM-COMMON OVERLAP The module being loaded is attempting to load code into an area reserved for COMMON. Use the loader's COmmon command to move COMMON up higher. ### PROGRAM TOO LARGE The program has loaded into the last location in memory and has wrapped around to load in Location 0. The program size must be decreased. Alternatively, compile in 64V mode and use SEG. ## REFERENCE TO UNDEFINED COMMON An attempt is being made to link to a COMMON name which has not been defined. This usually happens to users creating their own translators. ### SECTORED LOAD MODE INVALID A module compiled or assembled to load in R mode has been loaded in S mode. Use the MOde command to reset the load mode. It might be a good idea to be sure that all modules are correctly written, since the default load mode is 32R. ### SYMBOL NOT FOUND An attempt is being made to equate two symbols with the SYmbol command and the old symbol does not exist. ### SYMBOL TABLE FULL The symbol table has expanded down to location '4000. The last buffer cannot be assigned to the symbol table. Rebuild LOAD to load in higher memory locations, or reduce the number of symbols in the load. ### SYMBOL UNDEFINED An attempt is being made to equate two symbols; however, the old symbol is an undefined symbol in the symbol table. ### 64R LOAD MODE INVALID A module compiled or assembled to run in only 32K of memory is being loaded in 64R mode. Recompile or reassemble or change the load mode with the loader's MOde command. ### SEG LOADER ERROR MESSAGES ### BAD OBJECT FILE User is attempting to load file which has faulty code. The file may not be an object file or it may be incorrectly compiled. Fatal error, the load must be aborted. ### CAN'T LOAD IN SECTORED MODE The Loader is attempting to load code in sectored mode which has not been compiled in sectored mode. This could arise if trying to load a module compiled or assembled in 16S or 32S mode. It is unlikely that the average applications programmer will encounter this. Fatal error, abort load. ## CAN'T LOAD IN 64V OR 64R MODE The Loader is attempting to load code in 64V mode which is not compiled in that mode. This would arise if: - 1. A program was compiled in a mode other than 64V. - 2. A PMA module is written in code other than 64V and its mode is not specified. In case 1, the user should recompile the program. In case 2, which the average applications programmer is unlikely to encounter, the PMA module must be modified. Fatal error, abort load. ### **COMMAND ERROR** An unrecognized command was entered or the filenames/parameters following the command are incorrect. Usually not fatal. ## EXTERNAL MEMORY REFERENCE TO ILLEGAL SEGMENT An attempt was made to load a 64R mode program, causing a reference to an illegal segment number. Recompile in 64V mode. Fatal error, abort load. #### ILLEGAL SPLIT ADDRESS Incorrect use of the Loader's SPLIT command. Segments may be split at '4000 boundaries only (i.e., '4000, '10000, '14000, etc.). Not fatal; resplit segment. # MEMORY REFERENCE TO COMMON IN ILLEGAL SEGMENT An attempt was made to load a 64R mode program wherein COMMON would be allocated to an illegal segment number. Recompile in 64V mode. Fatal error, abort load. ### NO FREE SEGMENTS TO ASSIGN All SEG's segments have been allocated; no more are available at present. Use SYMBOL command to eliminate COMMON from assigned segments, thus reducing the number of assigned segments required. (User may need larger version of SEG and PRIMOS). Fatal error, abort load. ### NO ROOM IN SYMBOL TABLE Unlikely to occur; no user solution. A new issue of SEG with a bigger symbol table is required. Check with analyst. As a temporary measure, user may try to reduce number of symbols used in program. Fatal error, abort load. ## REFERENCE TO UNDEFINED SEGMENT Almost always caused by improper use of the SYMBOL command to allocate initialized COMMON. Initialized COMMON cannot be located with the SYMBOL command: use R/SYMBOL or A/SYMBOL instead. ### SECTOR ZERO BASE AREA FULL Extremely unlikely to occur. Not correctable at applications level. Check with analyst. Fatal error, abort load. ### SEGMENT WRAP AROUND TO ZERO An attempt has been made to load a 64R mode program. The program has exceeded 64K and is trying to be loaded over code previously loaded. Recompile in 64V mode. Fatal error, abort load. ### **RUN-TIME ERROR MESSAGES** ### ACCESS VIOLATION 64V mode Attempt to perform operations in segments to which user has no right. \*\*\*\*AD R-mode function Overflow or underflow in double-precision addition/subtraction (A\$66,S\$66). ### ALL REMOTE UNITS IN USE File System Attempt made to assign a remote unit when none are available. (Network error) [E\$FUIU] ### \*\*\*\* ALOG/ALOG 10 - ARGUMENT <=0 V-mode function Argument not greater than zero used in logarithm (ALOG, ALOG 10) function. ### filename ALREADY EXISTS Old file call Attempt to create a file or UFD with the name of one already existing. [CZ] ### ALREADY EXISTS File System Attempt made to create, in the UFD, a sub-UFD with the same name as one already existing. (CREA\$\$) [E\$EXST] ## \*\*\*\*AT R-mode function Both arguments are zero in the ATAN2 function. ### \*\*\*\* ATAN2 - BOTH ARGUMENTS = 0 V-mode function Both arguments are zero in the ATAN2 function. ### \*\*\*\* ATTDEV - BAD UNIT V-mode call Incorrect logical device unit number in the ATTDEV subroutine call. ### BAD CALL TO SEARCH Old file call Error in calling the SEARCH subroutine, e.g., incorrect parameter. [SA] ### BAD DAM FILE Old file call The DAM file specified has been corrupted – either by the programmer or by a system problem. [SS] ### **BAD DAM FILE** File System The DAM file specified has been corrupted – either by the programmer or by a system problem. (PRWF\$\$, SRCH\$\$). [E\$BDAM] BAD FAM SVC File System System problem; will not be seen by applications programmer. [E\$BFSV] BAD KEY File System Incorrect key value specified in subroutine argument. (ATCH\$\$, RDEN\$\$, SATR\$\$, SRCH\$\$, SGDR\$\$) [E\$BKEY] BAD PARAMETER Old file call Incorrect parameter value in subroutine call. [SA] BAD PASSWORD Old file call Incorrect password specified in ATTACH subroutine. Returns to PRIMOS level attached to no UFD. [AN] BAD PASSWORD File System Incorrect password specified in ATCH\$\$ subroutine. Returns to PRIMOS level attached to no UFD. [ATCH\$\$] [E\$BPAS] Note To protect UFD privacy the system does not allow the user to trap BAD PASSWORD errors. BAD RTNREC PRIMOS System error. BAD SEGDIR UNIT File System Error generated in accessing segment directory, i.e., PRIMOS file unit specified is not a segment directory. (SRCH\$\$) [E\$BSUN] BAD SEGMENT NUMBER File System Attempt made to access segment number outside valid range. [E\$BSGN] BAD SVC PRIMOS Bad supervisor call. In FORTRAN usually caused by program writing over itself. BAD TRUNCATE OF SEGDIR File System Error encountered in truncating segment directory. (SGDR\$\$) [E\$BTRN] BAD UFD File System UFD has become corrupted. (ATCH\$\$, CREA\$\$, GPAS\$\$, RDEN\$\$, SATR\$\$, SRCH\$\$) [E\$BUFD]. Calls to RDEN\$\$ return this as a trappable error; other commands return to the PRIMOS command level. BAD UNIT NUMBER File System PRIMOS file unit number specified is invalid – outside legal range. (PRWF\$\$, RDEN\$\$, SRCH\$\$, SGDR\$\$). [E\$BUNT] BEGINNING OF FILE File System Attempt was made to access locations before the beginning of the file. (PRWF\$\$. RDEN\$\$, SGDR\$\$) [E\$BOF] \*\*\*\*BN n R-mode function Device error in REWIND command on FORTRAN logical unit n. ### **BUFFER TOO SMALL** File System Buffer as defined is not large enough to accommodate entry to be read into it. (RDEN\$\$) [E\$BFTS] ### \*\*\*\* DATAN - BAD ARGUMENT V-mode function R-mode function The second argument in the DATAN2 function is zero. \*\*\*\*DE The exponent of a double-precision number has overflowed. DEVICE IN USE File System Attempt was made to ASSIGN a device currently assigned to another user. [E\$DVIU] ### **DEVICE NOT ASSIGNED** File System Attempt was made to perform I/O operations on a device before assigning that device. [E\$NASS] ### DEVICE NOT STARTED File System Attempt was made to access a disk not physically or logically connected to the system. If disk must be accessed, systems manager must start it up. [E\$DNS] ### \*\*\*\* DEXP - ARGUMENT TOO LARGE V-mode function The argument of the DEXP function is too large; i.e., it will give a result outside the legal range. ### \*\*\*\* DEXP - OVERFLOW/UNDERFLOW V-mode function An overflow or underflow condition occurred in calculating the DEXP function. ### **DIRECTORY NOT EMPTY** File System Attempt was made to delete a non-empty directory. (SRCH\$\$) [E\$DNTE] **DISK FULL** Old file call No more room for creating/extending any type of file on disk.[DJ] ### **DISK FULL** File System No more room for creating/extending any type of file on disk. (CREA\$\$, PRWF\$\$, SRCH\$\$, SGDR\$\$). [E\$DKFL] ### Note Space may be made available. Use the internal PRIMOS commands ATTACH, LISTF, and DELETE to remove files which are no longer needed. ### DISK I/O ERROR File System A read/write error was encountered in accessing disk. Returns immediately to PRIMOS level. Not correctable by applications programmer. (ATTCH\$\$, CREA\$\$, GPAS\$\$, PRWF\$\$, RDEN\$\$, SATR\$\$, SRCH\$\$, SGDR\$\$). [E\$DISK] ### DISK WRITE-PROTECTED File System An attempt has been made to write to a disk which is WRITE-protected. [E\$WTPR] DK ERROR Old file call A read/write error was encountered in accessing disk. [WB] \*\*\*\*DL R-mode function Argument was not greater than zero in DLOG or DLOG2 function. \*\*\*\* DLOG/DLOG2 - ARGUMENT< = 0 V-mode function Argument not greater than zero was used in DLOG or DLOG2 function. \*\*\*\*DN n R-mode function Device error (end of file) on FORTRAN logical unit n. \*\*\*\* DSIN/DCOS - ARGUMENT RANGE ERROR V-mode function Argument outside legal range for DSIN or DCOS function. \*\*\*\* DSQRT - ARGUMENT <0 V-mode function Negative argument in DSQRT function. \*\*\*\* DT R-mode function Second argument is zero in DATAN2 function. (D\$22) **DUPLICATE NAME** Old file call Attempt to create/rename a file with the name of an existing file. [CZ] \*\*\*\*DZ R-mode function Attempt to divide by zero (double-precision). END OF FILE File System Attempt to access location after the end of the file. (PRWF\$\$, RDEN\$\$, SGDR\$\$) [E\$EOF] \*\*\*\*EQ R-mode function Exponent overflow. (A\$81) \*\*\*\* EX R-mode function Exponent function value too large in EXP or DEXP function. \*\*\*\* EXP - ARGUMENT TOO LARGE V-mode function The argument of the EXP function is too large, i.e., it will give a result outside the legal range. \*\*\*\* EXP - OVERFLOW V-mode function Overflow occurred in calculating the EXP function. **FAM ABORT** File System System error. [E\$FABT] FAM - BAD STARTUP File System System error. [E\$FBST] FAM OP NOT COMPLETE File System Network error. [E\$FONC] \*\*\*\*FE R-mode function Error in FORMAT statement. FORMAT statements are not completely checked at compile time. (F\$IO) FILE IN USE File System Attempt made to open a file already opened or to close/delete a file opened by another user, etc. (SRCH\$\$) [E\$FDEL] FILE OPEN ON DELETE File System Attempt made to delete a file which is open. (SRCH\$\$) [E\$FDEL] FILE TOO BIG File System Attempt made to increase size of segment directory beyond size limit. (SGDR\$\$) [E\$FITB] \*\*\*\*FN n R-mode function Device error in BACKSPACE command on FORTRAN logical unit n. \*\*\*\* F\$BN - BAD LOGICAL UNIT V-mode function FORTRAN logical unit number out of range. \*\*\*\* F\$FLEX - DOUBLE-PRECISION DIVIDE BY ZERO 64V mode Attempt has been made to divide by zero. \*\*\*\* F\$FLEX - DOUBLE-PRECISION EXPONENT OVERFLOW 64V mode Exponent of a double-precision number has exceeded maximum. \*\*\*\* F\$FLEX - REAL => INTEGER CONVERSION ERROR 64V mode Magnitude of real number too great for integer conversion. \*\*\*\* F\$FLEX - SINGLE-PRECISION DIVIDE BY ZERO 64V mode Attempt has been made to divide by zero. \*\*\*\* F\$FLEX - SINGLE-PRECISION EXPONENT OVERFLOW 64V mode Exponent of a single-precision number has exceeded maximum. \*\*\*\* F\$IO - FORMAT ERROR V-mode function Incorrect FORMAT statement. FORMAT statements are not completely checked at compile time. \*\*\*\* F\$IO - FORMAT/DATA MISMATCH V-mode function Input data does not correspond to FORMAT statement. \*\*\*\* F\$IO - NULL READ UNIT V-mode function FORTRAN logical unit for READ statement not configured properly. \*\*\*\*II R-mode function Exponentiation exceeds integer size. (E\$11) ### ILLEGAL INSTRUCTION AT octal-location R mode and 64V mode An instruction at octal-location cannot be identified by the computer. **ILLEGAL NAME** File System Illegal name specified for a file or UFD. (CREA\$\$, SRCH\$\$) [E\$BNAM] ILL REMOTE REF File System Attempt to perform network operations by user not on network. [E\$IREM] **ILLEGAL SEGNO** 64V mode Program references a non-existent segment or a segment number greater than those available to the user. ILLEGAL TREENAME File System The string specified for a treename is syntactically incorrect. [E\$ITRE] \*\*\*\*IM R-mode function Overflow or underflow occurred during a multiply. (M\$11, E\$11) filename IN USE Old file call Attempt made to open a file already opened, or to close/delete a file opened by another user, etc. [SI] INVALID FAM FUNCTION CODE File System System error. [E\$FIFC] \*\*\*\* I\*\*I - ARGUMENT ERROR V-mode function Exponentiation exceeds integer size. \*\*\*\*LG R-mode function Argument not greater than zero in ALOG or ALOG10 function. MAX REMOTE USERS EXCEEDED File System No more users may access the network. [E\$TMRU] NAME TOO LONG File System Length of name in argument list exceeds 32 characters. [E\$NMLG] NO AVAILABLE SEGMENTS 64V mode Additional segment(s) required – none available. User should log out to release assigned segments and try again later. NO PHANTOMS AVAILABLE File System An attempt has been made to spawn a phantom. All configured phantoms are already in use. [E\$NPHA] NO RIGHT File System User does not have access right to file, or does not have write access in UFD when attempting to create a sub-UFD. (CREA\$\$, GPAS\$\$, SATR\$\$, SRCH\$\$, SGDR\$\$) [E\$NRIT] NO ROOM File System An attempt has been made to add to a table of assignable devices with a DISKS or ASSIGN AMLC command and the table is already filled. [E\$ROOM] NO TIME File System Clock not started. System error. [E\$NTIM] NO UFD ATTACHED Old file call User not attached to a UFD [AL, SL]. Usually occurs after attempt to attach with a bad password. NO UFD ATTACHED File System User not attached to a UFD. (ATCH\$\$, CREA\$\$, GPAS\$\$, SATR\$\$, SRCH\$\$). [E\$NATT] Usually occurs after attempt to attach with a bad password. NO VECTOR R and 64V mode User error in program has caused PRIMOS to attempt to access an unloaded element. - 1. A UII, PSU, or FLEX to location 0 - 2. Trap to location 0 - 3. SVC switch on, SVC trap and location '65 is 0. NOT A SEGDIR File System Attempt to perform segment director operations on a file which is not a segment directory. (SRCH\$\$) [E\$NTSD] NOT A UFD Old file call Attempt to perform UFD operations on a file which is not a UFD. |AR| NOT A UFD File System Attempt to perform UFD operations on a file which is not a UFD. (ATCHS\$, GPAS\$\$, SRCH\$\$). [E\$NTUD] ### device-name NOT ASSIGNED PRIMOS User program has attempted to access an I/O device which has not been assigned to the user by a PRIMOS command. ### filename NOT FOUND Old file call File specified in subroutine call not found. [AH, SH] ### filename NOT FOUND File System File specified in subroutine call not found. (ATCH\$\$, GPAS\$\$, SATR\$\$, SRCH\$\$) [E\$FNTF] #### filename NOT FOUND IN SEGDIR File System Filename specified in subroutine call not found in specified segment directory. (SRCH\$\$, SGDR\$\$) [E\$FNTS] NULL READ UNIT **PRIMOS** Program has attempted to read with a bad unit number. This may be caused by a program overwriting itself (array out of bounds). **OLD PARTITION** File System Attempt to perform, in an old file partition, an operation possible only in a new file partition; e.g., date/time information access. (SATR\$\$) [E\$OLDP] \*\*\*\*PA n R-mode function PAUSE statement n (octal) encountered during program execution \*\*\*\* PAUSE n V-mode function PAUSE statement n (octal) encountered during program execution. POINTER FAULT 64V mode Reference has been made to an argument or instruction not in memory. The two usual causes of this are an incomplete load (unsatisfied references), or incomplete argument list in a subroutine or function call. #### POINTER MISMATCH **PRIMOS** Internal file pointers have become corrupted. No user remedial action possible. System Administrator must correct. [PC, DC, AC] #### PROGRAM HALT AT octal-location R mode and 64V mode Program control has been lost. The program has probably written over itself or the load was incomplete (R-mode). PRWFIL BOF Old file call Attempt by PRWFIL subroutine to access location before beginning of file. [PG] **PRWFIL EOF** Old file call Attempt by PRWFIL subroutine to access location after end of file. |PE| #### PRWFIL POINTER MISMATCH Old file call The internal file pointers in the PRWFIL subroutine have become corrupted. #### PRWFIL UNIT NOT OPEN Old file call The PRWFIL subroutine is attempting to perform operations using a PRIMOS file unit number on which no file is open. #### PTR MISMATCH File System Internal file pointers have become corrupted. No user remedial action possible. (ATCH\$\$, CREA\$\$, GPAS\$\$, PRWF\$\$, RDEN\$\$, SATR\$\$, SRCH\$\$, SGDR\$\$). [E\$PTRM]. Consult system manager. #### REMOTE LINE DOWN File System Remote call-in access to computer not enabled. [E\$RLDN] \*\*\*\*RI R-mode function Argument is too large for real-to-integer conversion. (C\$12) \*\*\*\*RN n R-mode function Device error or end-of-file in READ statement on FORTRAN logical unit n. \*\*\*\*SE R-mode function Single precision exponent overflow. SEG-DIR ER Old file call Error encountered in segment directory operation. [SQ] SEGDIR UNIT NOT OPEN File System Attempt has been made to reference a segment directory which is not open. (SRCH\$\$) [E\$SUNO] SEM OVERFLOW File System System error [E\$SEMO] \*\*\*\* SIN/COS - ARGUMENT TOO LARGE V-mode function Argument too large for SIN or COS function. \*\*\*\*SQ R-mode function Negative argument in SQRT or DSQRT function. \*\*\*\* SQRT - ARGUMENT<0 V-mode function Negative argument in SQRT function. \*\*\*\*ST n R-mode function STOP statement n (octal) encountered during program execution. \*\*\*\* STOP n V-mode function STOP statement n (octal) encountered during program execution. \*\*\*\*SZ R-mode function Attempt to divide by zero (single-precision). TOO MANY UFD LEVELS File System Attempt to create more than 72 levels of sub-UFDs. This error occurs only on old file partitions; new file partitions have no limit on UFD levels. [E\$TMUL] UFD FULL Old file call No more room in UFD. [SK] UFD FULL File System UFD has no room for more files and/or sub-UFD's. Occurs only in old file partitions. (CREA\$\$, SRCH\$\$) [E\$FDFL] UFD OVERFLOW No more room in UFD. UNIT IN USE Old file call Old file call Attempt to open file on PRIMOS file unit already in use. [SI]. UNIT IN USE File System Attempt to open file on PRIMOS file unit already in use. (SRCH\$\$). [E\$UIUS] UNIT NOT OPEN Old file call Attempt to perform operations with a file unit number on which no file has been opened. [PD, SD] UNIT NOT OPEN File System Attempt to perform operations with a file unit number on which no file has been opened. (PRWF\$\$, RDEN\$\$, SRCH\$\$, SGDR\$\$). [E\$UNOP] UNIT OPEN ON DELETE Old file call Attempt to delete file without having first closed it. [SD] \*\*\*\*WN n R-mode function Device error or end-of-file in WRITE statement on FORTRAN logical unit n. \*\*\*\*XX R-mode function Integer argument >32767. | #, usage in PMA 14–5<br>%, usage in PMA 14–5 | C-bit to A, ACA, (SRV) 11–22 | APPLIB, system library 8-1 | |-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | | | | | %, usage in PMA 14-5 | 0 511 (0 11, 110/11, (511 ) 11 22 | | | | fullword, A, (I) 12–9 | Application library 9 1 | | | | Application library 8–1 | | &, ampersand character in | halfword, AH, (I) 12–10 | ARFA (I) 12–5 | | | | | | macros 17–2 | L bit to L, ADLL, (V) 11–23 | ARGT (I) 12–20 | | ***, dummy instruction 14-5 | | ADOTT (TI) 44 40 | | , duminy mstruction 14-5 | L to field address, ALFA, | ARGT (V) 11–43 | | **, initial zero 14-6 | (V) 11-15 | Argument | | , | | | | *, current location 14–6 | link to register, ADLR, | identifiers, macro 17-2, 17-3, | | | <u> </u> | | | *CMHIGH, R-mode load map | (I) 12–10 | 17–4 | | | | 1 | | entry 4–3 | long, ADL (V) 11–22 | pointer pseudo-operation, | | *CMLOW, R-mode load map | one to A ATA (CDV) 11 00 | | | | one to A, ALA (SRV) 11–22 | AP 16-7 | | entry 4-3 | register to field address | references, macro 17-2, 17-4 | | | | 16161611668, Illa610 17-2, 17-4 | | *HIGH, R-mode load map | register, ARFA, (I) 12–5 | substitution, macro 17-3 | | | | | | entry 4–3 | to bottom of queue, ABQ, | transfer template, AP 9–7 | | *HIGH, SEG load map entry 5-4 | | | | | (I) 12–21 | transfer, ARGT, (I) 12–20 | | *LOW, R-mode load map | to bottom of queue, ABQ, | | | <u> -</u> | to bottom of queue, ADQ, | transfer, ARGT, (V) 11–43 | | entry 4–3 | (V) 11-49 | value expressions, macro 17-3 | | | | | | *LOW, SEG load map entry 5-4 | to top of queue, ATQ, (I) 12–21 | values in parentheses, | | *DDDZ D 1 - 1 - 1 - 1 | | | | *PBRK, R-mode load map | to top of queue, ATQ, | macro 17–3 | | • | | | | entry 4–3 | (V) 11-49 | values, macro 17-1, 17-3, 17-4 | | *STACK, SEG load map entry 5-4 | trate to A A 2 A (CDV) 11 22 | Argumenta macro 17 9 | | 5171OK, ond load map entry 3-4 | two to A, A2A (SRV) 11-22 | Arguments, macro 17–2 | | *START, R-mode load map | ADD (SRV) 11-22 | Arithmetic instruction register | | o 11 may at mode road map | | | | entry 4-3 | Adding modules to a SEG | usage (I-mode only) 11–10 | | +0.00 A D.00 0 D.01 1 | | | | *START, SEG load map entry 5–4 | runfile 5-7 | Arithmetic operators 15–8 | | | | | | *SYM, R-mode load map | Addition operator 15-9 | ARL (SRV) 11-51 | | | <b>^</b> | | | entry 4–3 | Address | ARR (SRV) 11-51 | | *SYM, SEG load map entry 5–4 | 1 - ft - tt 1 | ADC (CDM) 44 F4 | | | definition pseudo-operations, | ÁRS (SRV) 11–51 | | *UII, R-mode load map entry 4-4 | AD 16-1 | ASCII 18-5 | | | AD 10-1 | | | 16S address calculation | formation 18–4 | character set B-1 | | | | | | flowcharts 10–11 | special case selection 9–18 | character strings 15–5 | | | | S . | | 16S summary 10-10 | mode, selecting the 4–5 | constants 18–5 | | 22D address calculation | | | | 32R address calculation | pointer (AP) 9-2 | Assembler | | flowcharts 10-16 | | attribute references 17-2 | | 110 W GITAL 13 10-10 | resolution, role of | attribute references 17-2 | | 32R summary 10–13 | assembler 10–3 | attributes 15-11, A-1 | | | | | | 32S (includes 32R when S=0) | resolution, role of loader 4–4, | error messages C-1 | | | | | | summary 10-12 | 10-3 | formats (I) 14–7 | | | | . , | | 32S address calculation 10–13 | space, virtual 4–5 | messages 3–2 | | 64R address calculation | | | | 041 addiess calculation | truncation (SR) 10–2 | Assembly control pseudo- | | flowcharts 10–23 | Addresses | operations AC 16 1 | | | Addresses | operations, AC 16–1 | | 64R summary 10-20 | relative 18–4 | Asterisk (current location), | | | 161dilve 10-4 | | | 64V address calculation | symbolic, PMA 14–5 | PMA 14-6 | | fl l + 40 04 | | | | flowcharts 10–31 | Addressing mode, ADMOD, | Asterisk, double, PMA 14–6 | | 64V hono pogistor polotico 10 00 | • | | | 64V base register relative 10–28 | (I) 12-1 | ATQ (I) 12–21 | | 64V procedure relative 10-28 | | | | | Addressing mode, ADMOD, | ATQ (V) 11–49 | | 64V two word memory | | Attributes, assembler 15-11, 17-2, | | | (V) 11-1 | 71(11) utes, assembler 15-11, 17-2, | | reference 10-29 | ADL (V) 11–22 | A-1 | | | | ** 1 | | :, assembler notation 15–10 | ADLL (V) 11–23 | | | DMA literale 14 C | | | | =, PMA literals 14–6 | | מ | | | ADLK 111 12-10 | В | | @ (non SEC mode) accombler | ADLR (I) 12-10 | _ | | @ (non-SEG mode) assembler | | _ | | | ADMOD (I) 12-1 | BACK pseudo-operation 16-8 | | @ (non-SEG mode) assembler notation 15-8 | ADMOD (I) 12–1<br>ADMOD (V) 11–1 | BACK pseudo-operation 16-8 | | notation 15–8 | ADMOD (I) 12–1<br>ADMOD (V) 11–1 | BACK pseudo-operation 16–8<br>Base area problems, how to | | notation 15–8 | ADMOD (I) 12-1<br>ADMOD (V) 11-1<br>Advanced debugging | BACK pseudo-operation 16-8 | | | ADMOD (I) 12-1<br>ADMOD (V) 11-1<br>Advanced debugging | BACK pseudo-operation 16-8<br>Base area problems, how to<br>resolve 4-5, 4-6, 5-8 | | notation 15-8 | ADMOD (I) 12-1<br>ADMOD (V) 11-1<br>Advanced debugging<br>techniques 7-2 | BACK pseudo-operation 16-8 Base area problems, how to resolve 4-5, 4-6, 5-8 Base areas, R-mode load map | | notation 15-8 | ADMOD (I) 12-1<br>ADMOD (V) 11-1<br>Advanced debugging<br>techniques 7-2 | BACK pseudo-operation 16-8 Base area problems, how to resolve 4-5, 4-6, 5-8 Base areas, R-mode load map | | notation 15-8 A A left logical, ALL, (SRV) 11-51 | ADMOD (I) 12–1<br>ADMOD (V) 11–1<br>Advanced debugging<br>techniques 7–2<br>Advanced features in loader, use | BACK pseudo-operation 16-8 Base area problems, how to resolve 4-5, 4-6, 5-8 Base areas, R-mode load map description 4-4 | | notation 15-8 A A left logical, ALL, (SRV) 11-51 | ADMOD (I) 12-1<br>ADMOD (V) 11-1<br>Advanced debugging<br>techniques 7-2 | BACK pseudo-operation 16-8 Base area problems, how to resolve 4-5, 4-6, 5-8 Base areas, R-mode load map description 4-4 | | notation 15-8 A A left logical, ALL, (SRV) 11-51 A left rotate, ALR, (SRV) 11-51 | ADMOD (I) 12–1 ADMOD (V) 11–1 Advanced debugging techniques 7–2 Advanced features in loader, use of 4–4 | BACK pseudo-operation 16-8 Base area problems, how to resolve 4-5, 4-6, 5-8 Base areas, R-mode load map description 4-4 Base areas, SEG load map | | notation 15-8 A A left logical, ALL, (SRV) 11-51 A left rotate, ALR, (SRV) 11-51 A left shift, ALS, (SRV) 11-51 | ADMOD (I) 12–1<br>ADMOD (V) 11–1<br>Advanced debugging<br>techniques 7–2<br>Advanced features in loader, use | BACK pseudo-operation 16-8 Base area problems, how to resolve 4-5, 4-6, 5-8 Base areas, R-mode load map description 4-4 Base areas, SEG load map | | notation 15-8 A A left logical, ALL, (SRV) 11-51 A left rotate, ALR, (SRV) 11-51 A left shift, ALS, (SRV) 11-51 | ADMOD (I) 12–1 ADMOD (V) 11–1 Advanced debugging techniques 7–2 Advanced features in loader, use of 4–4 Advanced SEG features 5–7 | BACK pseudo-operation 16-8 Base area problems, how to resolve 4-5, 4-6, 5-8 Base areas, R-mode load map description 4-4 Base areas, SEG load map entry 5-6 | | notation 15-8 A A left logical, ALL, (SRV) 11-51 A left rotate, ALR, (SRV) 11-51 | ADMOD (I) 12–1 ADMOD (V) 11–1 Advanced debugging techniques 7–2 Advanced features in loader, use of 4–4 | BACK pseudo-operation 16-8 Base area problems, how to resolve 4-5, 4-6, 5-8 Base areas, R-mode load map description 4-4 Base areas, SEG load map entry 5-6 | | notation 15–8 A A left logical, ALL, (SRV) 11–51 A left rotate, ALR, (SRV) 11–51 A left shift, ALS, (SRV) 11–51 A register details 3–3 | ADMOD (I) 12–1 ADMOD (V) 11–1 Advanced debugging techniques 7–2 Advanced features in loader, use of 4–4 Advanced SEG features 5–7 AH (I) 12–10 | BACK pseudo-operation 16-8 Base area problems, how to resolve 4-5, 4-6, 5-8 Base areas, R-mode load map description 4-4 Base areas, SEG load map entry 5-6 Base register relative, memory refer- | | notation 15-8 A A left logical, ALL, (SRV) 11-51 A left rotate, ALR, (SRV) 11-51 A left shift, ALS, (SRV) 11-51 A register details 3-3 A right logical, ARL, (SRV) 11-51 | ADMOD (I) 12-1 ADMOD (V) 11-1 Advanced debugging techniques 7-2 Advanced features in loader, use of 4-4 Advanced SEG features 5-7 AH (I) 12-10 ALA (SRV) 11-22 | BACK pseudo-operation 16-8 Base area problems, how to resolve 4-5, 4-6, 5-8 Base areas, R-mode load map description 4-4 Base areas, SEG load map entry 5-6 | | notation 15-8 A A left logical, ALL, (SRV) 11-51 A left rotate, ALR, (SRV) 11-51 A left shift, ALS, (SRV) 11-51 A register details 3-3 A right logical, ARL, (SRV) 11-51 | ADMOD (I) 12-1 ADMOD (V) 11-1 Advanced debugging techniques 7-2 Advanced features in loader, use of 4-4 Advanced SEG features 5-7 AH (I) 12-10 ALA (SRV) 11-22 | BACK pseudo-operation 16-8 Base area problems, how to resolve 4-5, 4-6, 5-8 Base areas, R-mode load map description 4-4 Base areas, SEG load map entry 5-6 Base register relative, memory referreference instruction | | notation 15-8 A A left logical, ALL, (SRV) 11-51 A left rotate, ALR, (SRV) 11-51 A left shift, ALS, (SRV) 11-51 A register details 3-3 A right logical, ARL, (SRV) 11-51 A right rotate, ARR, (SRV) 11-51 | ADMOD (I) 12-1 ADMOD (V) 11-1 Advanced debugging techniques 7-2 Advanced features in loader, use of 4-4 Advanced SEG features 5-7 AH (I) 12-10 ALA (SRV) 11-22 ALFA (V) 11-15 | BACK pseudo-operation 16-8 Base area problems, how to resolve 4-5, 4-6, 5-8 Base areas, R-mode load map description 4-4 Base areas, SEG load map entry 5-6 Base register relative, memory refer- reference instruction formats 10-6 | | notation 15-8 A A left logical, ALL, (SRV) 11-51 A left rotate, ALR, (SRV) 11-51 A left shift, ALS, (SRV) 11-51 A register details 3-3 A right logical, ARL, (SRV) 11-51 | ADMOD (I) 12-1 ADMOD (V) 11-1 Advanced debugging techniques 7-2 Advanced features in loader, use of 4-4 Advanced SEG features 5-7 AH (I) 12-10 ALA (SRV) 11-22 ALFA (V) 11-15 | BACK pseudo-operation 16-8 Base area problems, how to resolve 4-5, 4-6, 5-8 Base areas, R-mode load map description 4-4 Base areas, SEG load map entry 5-6 Base register relative, memory refer- reference instruction formats 10-6 | | notation 15-8 A A left logical, ALL, (SRV) 11-51 A left rotate, ALR, (SRV) 11-51 A left shift, ALS, (SRV) 11-51 A register details 3-3 A right logical, ARL, (SRV) 11-51 A right rotate, ARR, (SRV) 11-51 A right shift, ARS, (SRV) 11-51 | ADMOD (I) 12-1 ADMOD (V) 11-1 Advanced debugging techniques 7-2 Advanced features in loader, use of 4-4 Advanced SEG features 5-7 AH (I) 12-10 ALA (SRV) 11-22 ALFA (V) 11-15 ALL (SRV) 11-51 | BACK pseudo-operation 16-8 Base area problems, how to resolve 4-5, 4-6, 5-8 Base areas, R-mode load map description 4-4 Base areas, SEG load map entry 5-6 Base register relative, memory refer- reference instruction formats 10-6 Base registers 9-12 | | notation 15-8 A A left logical, ALL, (SRV) 11-51 A left rotate, ALR, (SRV) 11-51 A left shift, ALS, (SRV) 11-51 A register details 3-3 A right logical, ARL, (SRV) 11-51 A right rotate, ARR, (SRV) 11-51 | ADMOD (I) 12-1 ADMOD (V) 11-1 Advanced debugging techniques 7-2 Advanced features in loader, use of 4-4 Advanced SEG features 5-7 AH (I) 12-10 ALA (SRV) 11-22 ALFA (V) 11-15 | BACK pseudo-operation 16-8 Base area problems, how to resolve 4-5, 4-6, 5-8 Base areas, R-mode load map description 4-4 Base areas, SEG load map entry 5-6 Base register relative, memory refer- reference instruction formats 10-6 Base registers 9-12 | | notation 15-8 A A left logical, ALL, (SRV) 11-51 A left rotate, ALR, (SRV) 11-51 A left shift, ALS, (SRV) 11-51 A register details 3-3 A right logical, ARL, (SRV) 11-51 A right rotate, ARR, (SRV) 11-51 A right shift, ARS, (SRV) 11-51 A [I] 12-9 | ADMOD (I) 12-1 ADMOD (V) 11-1 Advanced debugging techniques 7-2 Advanced features in loader, use of 4-4 Advanced SEG features 5-7 AH (I) 12-10 ALA (SRV) 11-22 ALFA (V) 11-15 ALL (SRV) 11-51 ALR (SRV) 11-51 | BACK pseudo-operation 16-8 Base area problems, how to resolve 4-5, 4-6, 5-8 Base areas, R-mode load map description 4-4 Base areas, SEG load map entry 5-6 Base register relative, memory refer- reference instruction formats 10-6 Base registers 9-12 Base registers, PMA formats 14-6 | | notation 15-8 A A left logical, ALL, (SRV) 11-51 A left rotate, ALR, (SRV) 11-51 A left shift, ALS, (SRV) 11-51 A register details 3-3 A right logical, ARL, (SRV) 11-51 A right rotate, ARR, (SRV) 11-51 A right shift, ARS, (SRV) 11-51 A [I] 12-9 A2A (SRV) 11-22 | ADMOD (I) 12-1 ADMOD (V) 11-1 Advanced debugging techniques 7-2 Advanced features in loader, use of 4-4 Advanced SEG features 5-7 AH (I) 12-10 ALA (SRV) 11-22 ALFA (V) 11-15 ALL (SRV) 11-51 | BACK pseudo-operation 16-8 Base area problems, how to resolve 4-5, 4-6, 5-8 Base areas, R-mode load map description 4-4 Base areas, SEG load map entry 5-6 Base register relative, memory refer- reference instruction formats 10-6 Base registers 9-12 | | notation 15-8 A A left logical, ALL, (SRV) 11-51 A left rotate, ALR, (SRV) 11-51 A left shift, ALS, (SRV) 11-51 A register details 3-3 A right logical, ARL, (SRV) 11-51 A right rotate, ARR, (SRV) 11-51 A right shift, ARS, (SRV) 11-51 A [I] 12-9 A2A (SRV) 11-22 | ADMOD (I) 12-1 ADMOD (V) 11-1 Advanced debugging techniques 7-2 Advanced features in loader, use of 4-4 Advanced SEG features 5-7 AH (I) 12-10 ALA (SRV) 11-22 ALFA (V) 11-15 ALL (SRV) 11-51 ALR (SRV) 11-51 ALS (SRV) 11-51 ALS (SRV) 11-51 | BACK pseudo-operation 16-8 Base area problems, how to resolve 4-5, 4-6, 5-8 Base areas, R-mode load map description 4-4 Base areas, SEG load map entry 5-6 Base register relative, memory refer- reference instruction formats 10-6 Base registers 9-12 Base registers, PMA formats 14-6 BCEQ (I) 12-3 | | notation 15-8 A A left logical, ALL, (SRV) 11-51 A left rotate, ALR, (SRV) 11-51 A left shift, ALS, (SRV) 11-51 A register details 3-3 A right logical, ARL, (SRV) 11-51 A right rotate, ARR, (SRV) 11-51 A right shift, ARS, (SRV) 11-51 A [I] 12-9 A2A (SRV) 11-22 ABQ (I) 12-21 | ADMOD (I) 12-1 ADMOD (V) 11-1 Advanced debugging techniques 7-2 Advanced features in loader, use of 4-4 Advanced SEG features 5-7 AH (I) 12-10 ALA (SRV) 11-22 ALFA (V) 11-15 ALL (SRV) 11-51 ALR (SRV) 11-51 ALS (SRV) 11-51 ALS (SRV) 11-51 Ampersand character in macros | BACK pseudo-operation 16-8 Base area problems, how to resolve 4-5, 4-6, 5-8 Base areas, R-mode load map description 4-4 Base areas, SEG load map entry 5-6 Base register relative, memory refer- reference instruction formats 10-6 Base registers 9-12 Base registers, PMA formats 14-6 BCEQ [I] 12-3 BCEQ (V) 11-2 | | notation 15-8 A A left logical, ALL, (SRV) 11-51 A left rotate, ALR, (SRV) 11-51 A left shift, ALS, (SRV) 11-51 A register details 3-3 A right logical, ARL, (SRV) 11-51 A right rotate, ARR, (SRV) 11-51 A right shift, ARS, (SRV) 11-51 A [I] 12-9 A2A (SRV) 11-22 ABQ (I) 12-21 | ADMOD (I) 12-1 ADMOD (V) 11-1 Advanced debugging techniques 7-2 Advanced features in loader, use of 4-4 Advanced SEG features 5-7 AH (I) 12-10 ALA (SRV) 11-22 ALFA (V) 11-15 ALL (SRV) 11-51 ALR (SRV) 11-51 ALS (SRV) 11-51 ALS (SRV) 11-51 Ampersand character in macros | BACK pseudo-operation 16-8 Base area problems, how to resolve 4-5, 4-6, 5-8 Base areas, R-mode load map description 4-4 Base areas, SEG load map entry 5-6 Base register relative, memory refer- reference instruction formats 10-6 Base registers 9-12 Base registers, PMA formats 14-6 BCEQ [I] 12-3 BCEQ (V) 11-2 | | notation 15-8 A A left logical, ALL, (SRV) 11-51 A left rotate, ALR, (SRV) 11-51 A left shift, ALS, (SRV) 11-51 A register details 3-3 A right logical, ARL, (SRV) 11-51 A right rotate, ARR, (SRV) 11-51 A right shift, ARS, (SRV) 11-51 A (I) 12-9 A2A (SRV) 11-22 ABQ (I) 12-21 ABQ (V) 11-49 | ADMOD (I) 12-1 ADMOD (V) 11-1 Advanced debugging techniques 7-2 Advanced features in loader, use of 4-4 Advanced SEG features 5-7 AH (I) 12-10 ALA (SRV) 11-22 ALFA (V) 11-15 ALL (SRV) 11-51 ALR (SRV) 11-51 ALS (SRV) 11-51 ALS (SRV) 11-51 AMpersand character in macros (&) 17-2 | BACK pseudo-operation 16-8 Base area problems, how to resolve 4-5, 4-6, 5-8 Base areas, R-mode load map description 4-4 Base areas, SEG load map entry 5-6 Base register relative, memory refer- reference instruction formats 10-6 Base registers 9-12 Base registers, PMA formats 14-6 BCEQ [I] 12-3 BCEQ (V) 11-2 BCGE (II) 12-3 | | notation 15-8 A A left logical, ALL, (SRV) 11-51 A left rotate, ALR, (SRV) 11-51 A left shift, ALS, (SRV) 11-51 A register details 3-3 A right logical, ARL, (SRV) 11-51 A right rotate, ARR, (SRV) 11-51 A right shift, ARS, (SRV) 11-51 A [I] 12-9 A2A (SRV) 11-22 ABQ (I) 12-21 | ADMOD (I) 12-1 ADMOD (V) 11-1 Advanced debugging techniques 7-2 Advanced features in loader, use of 4-4 Advanced SEG features 5-7 AH (I) 12-10 ALA (SRV) 11-22 ALFA (V) 11-15 ALL (SRV) 11-51 ALR (SRV) 11-51 ALS (SRV) 11-51 ALS (SRV) 11-51 AMpersand character in macros (&) 17-2 | BACK pseudo-operation 16-8 Base area problems, how to resolve 4-5, 4-6, 5-8 Base areas, R-mode load map description 4-4 Base areas, SEG load map entry 5-6 Base register relative, memory refer- reference instruction formats 10-6 Base registers 9-12 Base registers, PMA formats 14-6 BCEQ [I] 12-3 BCEQ (V) 11-2 BCGE (II) 12-3 | | notation 15-8 A A left logical, ALL, (SRV) 11-51 A left rotate, ALR, (SRV) 11-51 A left shift, ALS, (SRV) 11-51 A register details 3-3 A right logical, ARL, (SRV) 11-51 A right rotate, ARR, (SRV) 11-51 A right shift, ARS, (SRV) 11-51 A [I] 12-9 A2A (SRV) 11-22 ABQ (I) 12-21 ABQ (V) 11-49 ABS 16-5 | ADMOD (I) 12-1 ADMOD (V) 11-1 Advanced debugging techniques 7-2 Advanced features in loader, use of 4-4 Advanced SEG features 5-7 AH (I) 12-10 ALA (SRV) 11-22 ALFA (V) 11-15 ALL (SRV) 11-51 ALR (SRV) 11-51 ALS (SRV) 11-51 ALS (SRV) 11-51 ALS (SRV) 11-51 AMpersand character in macros (&) 17-2 ANA (SRV) 11-32 | BACK pseudo-operation 16-8 Base area problems, how to resolve 4-5, 4-6, 5-8 Base areas, R-mode load map description 4-4 Base areas, SEG load map entry 5-6 Base register relative, memory refer- reference instruction formats 10-6 Base registers 9-12 Base registers, PMA formats 14-6 BCEQ (I) 12-3 BCEQ (V) 11-2 BCGE (I) 12-3 BCGE (V) 11-2 | | notation 15-8 A A left logical, ALL, (SRV) 11-51 A left rotate, ALR, (SRV) 11-51 A left shift, ALS, (SRV) 11-51 A register details 3-3 A right logical, ARL, (SRV) 11-51 A right rotate, ARR, (SRV) 11-51 A right shift, ARS, (SRV) 11-51 A [I] 12-9 A2A (SRV) 11-22 ABQ (I) 12-21 ABQ (V) 11-49 ABS 16-5 | ADMOD (I) 12-1 ADMOD (V) 11-1 Advanced debugging techniques 7-2 Advanced features in loader, use of 4-4 Advanced SEG features 5-7 AH (I) 12-10 ALA (SRV) 11-22 ALFA (V) 11-15 ALL (SRV) 11-51 ALR (SRV) 11-51 ALS (SRV) 11-51 ALS (SRV) 11-51 ALS (SRV) 11-51 AMpersand character in macros (&) 17-2 ANA (SRV) 11-32 | BACK pseudo-operation 16-8 Base area problems, how to resolve 4-5, 4-6, 5-8 Base areas, R-mode load map description 4-4 Base areas, SEG load map entry 5-6 Base register relative, memory refer- reference instruction formats 10-6 Base registers 9-12 Base registers, PMA formats 14-6 BCEQ (I) 12-3 BCEQ (V) 11-2 BCGE (I) 12-3 BCGE (V) 11-2 | | notation 15-8 A A left logical, ALL, (SRV) 11-51 A left rotate, ALR, (SRV) 11-51 A left shift, ALS, (SRV) 11-51 A register details 3-3 A right logical, ARL, (SRV) 11-51 A right rotate, ARR, (SRV) 11-51 A right shift, ARS, (SRV) 11-51 A (I) 12-9 A2A (SRV) 11-22 ABQ (I) 12-21 ABQ (I) 12-21 ABQ (V) 11-49 ABS 16-5 Absolute integers 17-2 | ADMOD (I) 12-1 ADMOD (V) 11-1 Advanced debugging techniques 7-2 Advanced features in loader, use of 4-4 Advanced SEG features 5-7 AH (I) 12-10 ALA (SRV) 11-22 ALFA (V) 11-15 ALL (SRV) 11-51 ALR (SRV) 11-51 ALR (SRV) 11-51 ALR (SRV) 11-51 AMPersand character in macros (&) 17-2 ANA (SRV) 11-32 AND fullword, N, (I) 12-15 | BACK pseudo-operation 16-8 Base area problems, how to resolve 4-5, 4-6, 5-8 Base areas, R-mode load map description 4-4 Base areas, SEG load map entry 5-6 Base register relative, memory refer- reference instruction formats 10-6 Base registers 9-12 Base registers, PMA formats 14-6 BCEQ (I) 12-3 BCEQ (V) 11-2 BCGE (I) 12-3 BCGE (V) 11-2 BCGT (I) 12-3 | | notation 15-8 A A left logical, ALL, (SRV) 11-51 A left rotate, ALR, (SRV) 11-51 A left shift, ALS, (SRV) 11-51 A register details 3-3 A right logical, ARL, (SRV) 11-51 A right rotate, ARR, (SRV) 11-51 A right shift, ARS, (SRV) 11-51 A [I] 12-9 A2A (SRV) 11-22 ABQ (I) 12-21 ABQ (V) 11-49 ABS 16-5 | ADMOD (I) 12-1 ADMOD (V) 11-1 Advanced debugging techniques 7-2 Advanced features in loader, use of 4-4 Advanced SEG features 5-7 AH (I) 12-10 ALA (SRV) 11-22 ALFA (V) 11-15 ALL (SRV) 11-51 ALR (SRV) 11-51 ALS (SRV) 11-51 ALS (SRV) 11-51 ALS (SRV) 11-51 AMpersand character in macros (&) 17-2 ANA (SRV) 11-32 | BACK pseudo-operation 16-8 Base area problems, how to resolve 4-5, 4-6, 5-8 Base areas, R-mode load map description 4-4 Base areas, SEG load map entry 5-6 Base register relative, memory refer- reference instruction formats 10-6 Base registers 9-12 Base registers, PMA formats 14-6 BCEQ (I) 12-3 BCEQ (V) 11-2 BCGE (I) 12-3 BCGE (V) 11-2 | | notation 15-8 A A left logical, ALL, (SRV) 11-51 A left rotate, ALR, (SRV) 11-51 A left shift, ALS, (SRV) 11-51 A register details 3-3 A right logical, ARL, (SRV) 11-51 A right rotate, ARR, (SRV) 11-51 A right shift, ARS, (SRV) 11-51 A (I) 12-9 A2A (SRV) 11-22 ABQ (I) 12-21 ABQ (I) 12-21 ABQ (V) 11-49 ABS 16-5 Absolute integers 17-2 AC, assembly control pseudo- | ADMOD (I) 12-1 ADMOD (V) 11-1 Advanced debugging techniques 7-2 Advanced features in loader, use of 4-4 Advanced SEG features 5-7 AH (I) 12-10 ALA (SRV) 11-22 ALFA (V) 11-15 ALL (SRV) 11-51 ALR (SRV) 11-51 ALS (SRV) 11-51 ALS (SRV) 11-51 AMpersand character in macros (&) 17-2 ANA (SRV) 11-32 AND fullword, N, (I) 12-15 AND halfword, NH, (I) 12-15 | BACK pseudo-operation 16-8 Base area problems, how to resolve 4-5, 4-6, 5-8 Base areas, R-mode load map description 4-4 Base areas, SEG load map entry 5-6 Base register relative, memory refer- reference instruction formats 10-6 Base registers 9-12 Base registers, PMA formats 14-6 BCEQ (I) 12-3 BCEQ (V) 11-2 BCGE (I) 12-3 BCGT (I) 12-3 BCGT (I) 12-3 BCGT (V) 11-2 | | A A left logical, ALL, (SRV) 11-51 A left rotate, ALR, (SRV) 11-51 A left shift, ALS, (SRV) 11-51 A register details 3-3 A right logical, ARL, (SRV) 11-51 A right rotate, ARR, (SRV) 11-51 A right shift, ARS, (SRV) 11-51 A (I) 12-9 A2A (SRV) 11-22 ABQ (I) 12-21 ABQ (V) 11-49 ABS 16-5 Absolute integers 17-2 AC, assembly control pseudo-operations 16-1 | ADMOD (I) 12-1 ADMOD (V) 11-1 Advanced debugging techniques 7-2 Advanced features in loader, use of 4-4 Advanced SEG features 5-7 AH (I) 12-10 ALA (SRV) 11-22 ALFA (V) 11-15 ALL (SRV) 11-51 ALR (SRV) 11-51 ALR (SRV) 11-51 ALR (SRV) 11-51 AMpersand character in macros (&) 17-2 ANA (SRV) 11-32 AND fullword, N, (I) 12-15 AND halfword, NH, (I) 12-15 AND long, ANL, (V) 11-32 | BACK pseudo-operation 16-8 Base area problems, how to resolve 4-5, 4-6, 5-8 Base areas, R-mode load map description 4-4 Base areas, SEG load map entry 5-6 Base register relative, memory refer- reference instruction formats 10-6 Base registers 9-12 Base registers, PMA formats 14-6 BCEQ (I) 12-3 BCEQ (V) 11-2 BCGE (I) 12-3 BCGE (V) 11-2 BCGT (I) 12-3 | | A A left logical, ALL, (SRV) 11-51 A left rotate, ALR, (SRV) 11-51 A left shift, ALS, (SRV) 11-51 A register details 3-3 A right logical, ARL, (SRV) 11-51 A right rotate, ARR, (SRV) 11-51 A right shift, ARS, (SRV) 11-51 A (I) 12-9 A2A (SRV) 11-22 ABQ (I) 12-21 ABQ (V) 11-49 ABS 16-5 Absolute integers 17-2 AC, assembly control pseudo-operations 16-1 | ADMOD (I) 12-1 ADMOD (V) 11-1 Advanced debugging techniques 7-2 Advanced features in loader, use of 4-4 Advanced SEG features 5-7 AH (I) 12-10 ALA (SRV) 11-22 ALFA (V) 11-15 ALL (SRV) 11-51 ALR (SRV) 11-51 ALR (SRV) 11-51 ALR (SRV) 11-51 AMpersand character in macros (&) 17-2 ANA (SRV) 11-32 AND fullword, N, (I) 12-15 AND halfword, NH, (I) 12-15 AND long, ANL, (V) 11-32 | BACK pseudo-operation 16-8 Base area problems, how to resolve 4-5, 4-6, 5-8 Base areas, R-mode load map description 4-4 Base areas, SEG load map entry 5-6 Base register relative, memory refer- reference instruction formats 10-6 Base registers 9-12 Base registers, PMA formats 14-6 BCEQ (I) 12-3 BCEQ (V) 11-2 BCGE (I) 12-3 BCGE (V) 11-2 BCGT (I) 12-3 BCGT (V) 11-2 BCGT (V) 11-2 BCGT (V) 11-2 BCGT (V) 11-2 BCGT pseudo operation 16-10 | | A left logical, ALL, (SRV) 11-51 A left rotate, ALR, (SRV) 11-51 A left shift, ALS, (SRV) 11-51 A register details 3-3 A right logical, ARL, (SRV) 11-51 A right rotate, ARR, (SRV) 11-51 A right shift, ARS, (SRV) 11-51 A (I) 12-9 A2A (SRV) 11-22 ABQ (I) 12-21 ABQ (V) 11-49 ABS 16-5 Absolute integers 17-2 AC, assembly control pseudooperations 16-1 ACA (SRV) 11-22 | ADMOD (I) 12-1 ADMOD (V) 11-1 Advanced debugging techniques 7-2 Advanced features in loader, use of 4-4 Advanced SEG features 5-7 AH (I) 12-10 ALA (SRV) 11-22 ALFA (V) 11-15 ALL (SRV) 11-51 ALR (SRV) 11-51 ALR (SRV) 11-51 ALR (SRV) 11-51 AMDersand character in macros (&) 17-2 ANA (SRV) 11-32 AND fullword, N, (I) 12-15 AND long, ANL, (V) 11-32 AND to A, ANA, (SRV) 11-32 | BACK pseudo-operation 16-8 Base area problems, how to resolve 4-5, 4-6, 5-8 Base areas, R-mode load map description 4-4 Base areas, SEG load map entry 5-6 Base register relative, memory refer- reference instruction formats 10-6 Base registers 9-12 Base registers, PMA formats 14-6 BCEQ (I) 12-3 BCEQ (V) 11-2 BCGE (I) 12-3 BCGE (V) 11-2 BCGT (I) 12-3 BCGT (V) 11-2 BCGT (V) 11-2 BCGT (V) 11-2 BCI pseudo operation 16-10 BCLE (I) 12-3 | | A left logical, ALL, (SRV) 11-51 A left rotate, ALR, (SRV) 11-51 A left shift, ALS, (SRV) 11-51 A register details 3-3 A right logical, ARL, (SRV) 11-51 A right rotate, ARR, (SRV) 11-51 A right shift, ARS, (SRV) 11-51 A (I) 12-9 A2A (SRV) 11-22 ABQ (I) 12-21 ABQ (V) 11-49 ABS 16-5 Absolute integers 17-2 AC, assembly control pseudooperations 16-1 ACA (SRV) 11-22 | ADMOD (I) 12-1 ADMOD (V) 11-1 Advanced debugging techniques 7-2 Advanced features in loader, use of 4-4 Advanced SEG features 5-7 AH (I) 12-10 ALA (SRV) 11-22 ALFA (V) 11-15 ALL (SRV) 11-51 ALR (SRV) 11-51 ALR (SRV) 11-51 ALR (SRV) 11-51 AMDersand character in macros (&) 17-2 ANA (SRV) 11-32 AND fullword, N, (I) 12-15 AND long, ANL, (V) 11-32 AND to A, ANA, (SRV) 11-32 | BACK pseudo-operation 16-8 Base area problems, how to resolve 4-5, 4-6, 5-8 Base areas, R-mode load map description 4-4 Base areas, SEG load map entry 5-6 Base register relative, memory refer- reference instruction formats 10-6 Base registers 9-12 Base registers, PMA formats 14-6 BCEQ (I) 12-3 BCEQ (V) 11-2 BCGE (I) 12-3 BCGE (V) 11-2 BCGT (I) 12-3 BCGT (V) 11-2 BCGT (V) 11-2 BCGT (V) 11-2 BCI pseudo operation 16-10 BCLE (I) 12-3 | | A left logical, ALL, (SRV) 11-51 A left rotate, ALR, (SRV) 11-51 A left shift, ALS, (SRV) 11-51 A register details 3-3 A right logical, ARL, (SRV) 11-51 A right rotate, ARR, (SRV) 11-51 A right shift, ARS, (SRV) 11-51 A right shift, ARS, (SRV) 11-51 A (I) 12-9 A2A (SRV) 11-22 ABQ (I) 12-21 ABQ (V) 11-49 ABS 16-5 Absolute integers 17-2 AC, assembly control pseudooperations 16-1 ACA (SRV) 11-22 Access mode 18-6 | ADMOD (I) 12-1 ADMOD (V) 11-1 Advanced debugging techniques 7-2 Advanced features in loader, use of 4-4 Advanced SEG features 5-7 AH (I) 12-10 ALA (SRV) 11-22 ALFA (V) 11-15 ALL (SRV) 11-51 ALR (SRV) 11-51 ALS (SRV) 11-51 ALS (SRV) 11-51 AMpersand character in macros (&) 17-2 ANA (SRV) 11-32 AND fullword, N, (I) 12-15 AND halfword, NH, (I) 12-15 AND long, ANL, (V) 11-32 AND to A, ANA, (SRV) 11-32 ANL (V) 11-32 | BACK pseudo-operation 16-8 Base area problems, how to resolve 4-5, 4-6, 5-8 Base areas, R-mode load map description 4-4 Base areas, SEG load map entry 5-6 Base register relative, memory refer- reference instruction formats 10-6 Base registers 9-12 Base registers 9-12 Base registers, PMA formats 14-6 BCEQ (I) 12-3 BCEQ (V) 11-2 BCGE (I) 12-3 BCGE (V) 11-2 BCGT (I) 12-3 BCGT (V) 11-2 BCGT (V) 11-2 BCI pseudo operation 16-10 BCLE (I) 12-3 BCLE (V) 11-2 | | A left logical, ALL, (SRV) 11-51 A left rotate, ALR, (SRV) 11-51 A left shift, ALS, (SRV) 11-51 A register details 3-3 A right logical, ARL, (SRV) 11-51 A right rotate, ARR, (SRV) 11-51 A right shift, ARS, (SRV) 11-51 A (I) 12-9 A2A (SRV) 11-22 ABQ (I) 12-21 ABQ (V) 11-49 ABS 16-5 Absolute integers 17-2 AC, assembly control pseudooperations 16-1 ACA (SRV) 11-22 | ADMOD (I) 12-1 ADMOD (V) 11-1 Advanced debugging techniques 7-2 Advanced features in loader, use of 4-4 Advanced SEG features 5-7 AH (I) 12-10 ALA (SRV) 11-22 ALFA (V) 11-15 ALL (SRV) 11-51 ALR (SRV) 11-51 ALR (SRV) 11-51 ALR (SRV) 11-51 AMDersand character in macros (&) 17-2 ANA (SRV) 11-32 AND fullword, N, (I) 12-15 AND long, ANL, (V) 11-32 AND to A, ANA, (SRV) 11-32 | BACK pseudo-operation 16-8 Base area problems, how to resolve 4-5, 4-6, 5-8 Base areas, R-mode load map description 4-4 Base areas, SEG load map entry 5-6 Base register relative, memory refer- reference instruction formats 10-6 Base registers 9-12 Base registers 9-12 Base registers, PMA formats 14-6 BCEQ (I) 12-3 BCEQ (V) 11-2 BCGE (I) 12-3 BCGE (V) 11-2 BCGT (I) 12-3 BCGT (V) 11-2 BCGT (V) 11-2 BCI pseudo operation 16-10 BCLE (I) 12-3 BCLE (V) 11-2 | | A left logical, ALL, (SRV) 11-51 A left rotate, ALR, (SRV) 11-51 A left shift, ALS, (SRV) 11-51 A register details 3-3 A right logical, ARL, (SRV) 11-51 A right rotate, ARR, (SRV) 11-51 A right shift, ARS, (SRV) 11-51 A right shift, ARS, (SRV) 11-51 A (I) 12-9 A2A (SRV) 11-22 ABQ (I) 12-21 ABQ (V) 11-49 ABS 16-5 Absolute integers 17-2 AC, assembly control pseudooperations 16-1 ACA (SRV) 11-22 Access mode 18-6 AD, address definition pseudo- | ADMOD (I) 12-1 ADMOD (V) 11-1 Advanced debugging techniques 7-2 Advanced features in loader, use of 4-4 Advanced SEG features 5-7 AH (I) 12-10 ALA (SRV) 11-22 ALFA (V) 11-15 ALL (SRV) 11-51 ALR (SRV) 11-51 ALS (SRV) 11-51 ALS (SRV) 11-51 AMpersand character in macros (&) 17-2 ANA (SRV) 11-32 AND fullword, N, (I) 12-15 AND halfword, NH, (I) 12-15 AND long, ANL, (V) 11-32 AND to A, ANA, (SRV) 11-32 ANL (V) 11-32 AP, argument transfer | BACK pseudo-operation 16-8 Base area problems, how to resolve 4-5, 4-6, 5-8 Base areas, R-mode load map description 4-4 Base areas, SEG load map entry 5-6 Base register relative, memory refer- reference instruction formats 10-6 Base registers 9-12 Base registers, PMA formats 14-6 BCEQ (I) 12-3 BCEQ (V) 11-2 BCGE (I) 12-3 BCGT (V) 11-2 BCGT (I) 12-3 BCGT (V) 11-2 BCI pseudo operation 16-10 BCLE (I) 12-3 BCLE (V) 11-2 BCLE (V) 11-2 BCLE (V) 11-2 BCLE (I) 12-3 | | A left logical, ALL, (SRV) 11-51 A left rotate, ALR, (SRV) 11-51 A left shift, ALS, (SRV) 11-51 A register details 3-3 A right logical, ARL, (SRV) 11-51 A right rotate, ARR, (SRV) 11-51 A right shift, ARS, (SRV) 11-51 A right shift, ARS, (SRV) 11-51 A (I) 12-9 A2A (SRV) 11-22 ABQ (I) 12-21 ABQ (V) 11-49 ABS 16-5 Absolute integers 17-2 AC, assembly control pseudooperations 16-1 ACA (SRV) 11-22 Access mode 18-6 | ADMOD (I) 12-1 ADMOD (V) 11-1 Advanced debugging techniques 7-2 Advanced features in loader, use of 4-4 Advanced SEG features 5-7 AH (I) 12-10 ALA (SRV) 11-22 ALFA (V) 11-15 ALL (SRV) 11-51 ALR (SRV) 11-51 ALS (SRV) 11-51 ALS (SRV) 11-51 AMpersand character in macros (&) 17-2 ANA (SRV) 11-32 AND fullword, N, (I) 12-15 AND halfword, NH, (I) 12-15 AND long, ANL, (V) 11-32 AND to A, ANA, (SRV) 11-32 ANL (V) 11-32 | BACK pseudo-operation 16-8 Base area problems, how to resolve 4-5, 4-6, 5-8 Base areas, R-mode load map description 4-4 Base areas, SEG load map entry 5-6 Base register relative, memory refer- reference instruction formats 10-6 Base registers 9-12 Base registers 9-12 Base registers, PMA formats 14-6 BCEQ (I) 12-3 BCEQ (V) 11-2 BCGE (I) 12-3 BCGE (V) 11-2 BCGT (I) 12-3 BCGT (V) 11-2 BCGT (V) 11-2 BCI pseudo operation 16-10 BCLE (I) 12-3 BCLE (V) 11-2 | | BCNE (I) 12-3 | BMEQ, branch if magnitude is | condition code not equal, | |-------------------------------------------------------------|----------------------------------------------------------|---------------------------------------------------------| | BCR (I) 12–3 | equal to zero, (I) 12-3 | BCNE, (V) 11-2 | | BCR (V) 11-3 | BMEQ, branch if magnitude is | condition code not equal, | | BCS (I) 12-3 | equal to zero, (V) 11–3 | BCNE, (I) 12-3 | | BCS (V) 11-3 | BMGE, branch if magnitude is | floating register equal to zero, | | BDI1 (I) 12–3 | greater than or equal to zero, | BFEQ, (I) 12-2 | | BDX (V) 11-4 | (l) 12-3 | floating register equal to zero, | | BDY (V) 11-4 | BMGE, branch if magnitude is | BFEQ, (V) 11-4 floating register greater than or | | Begin macro definition pseudo- | greater than or equal to zero,<br>(V) 11–3 | equal to zero, BFGE, | | operation, MAC 16-16<br>BEQ (V) 11-4 | BMGT, branch if magnitude is | (I) 12-2 | | BES pseudo-operation 16–20 | greater than zero, (V) 11-3 | floating register greater than or | | BFEQ (I) 12-2 | BMGT, branch if magnitude is | equal to zero, BFGE, | | BFEQ (V) 11-4 | greater than zero, (I) 12-3 | $(\hat{V})$ 11-4 | | BFGE (I) 12-2 | BMLE, branch if magnitude is less | floating register greater than | | BFGE (V) 11-4 | than or equal to zero, | zero, BFGT, (I) 12-2 | | BFGT (V) 11-4 | (I) 12-3 | floating register greater than | | BFGT (I) 12–2 | BMLE, branch if magnitude is less | zero, BFGT, (V) 11-4 | | BFLE (V) 11-4 | than or equal to zero, | floating register less than or | | BFLE (I) 12-2 | (V) 11-3 BMIT brough if magnitude is less | equal to zero, BFLE,<br>(I) 12–2 | | BFLT (I) 12-2 | BMLT, branch if magnitude is less<br>than zero, (I) 12-3 | floating register less than or | | BFLT (V) 11-4<br>BFNE(I) 12-2 | BMLT, branch if magnitude is less | equal to zero, BFLE, | | BFNE (V) 11-4 | than zero, (V) 11-3 | (V) 11-4 | | BGE (V) 11-4 | BMNE, branch if magnitude is not | floating register less than zero, | | BGT (V) 11-4 | equal to zero, (I) 12-3 | BFLT, (I) 12-2 | | BHD1 (Í) 12–3 | BMNE, branch if magnitude is not | floating register less than zero, | | BHD2 (I) 12-3 | equal to zero, (V) 11–3 | BFLT, (V) 11-4 | | BHD4 (I) 12-3 | BNE, branch if A register not equal | floating register not equal to | | BHGE (I) 12-2 | to zero, (V) 11-4 | zero, BFNE, (1) 12-2 | | BHGT (I) 12-2 | BRAN, branch (I) 12-1 | floating register not equal to<br>zero, BFNE, (V) 11–4 | | BHI2 (I) 12-3 | BRAN, branch (V) 11-2 Branch instruction format 9-16 | half register greater than or | | BHI4 (I) 12-3<br>BHLE (I) 12-2 | Branch if | equal to zero, BHGE, | | BHLT (I) 12-2 | A register equal to zero, BEQ, | (I) 12-2 | | BHNE (I) 12-2 | (V) 11-4 | half register greater than zero, | | Binary 18-5 | A register greater than or equal | BHGT, (Ĭ) 12-2 | | constants 15–3 | to zero, BGE, (V) 11-4 | half register less than or equal | | exponent 15–5 | A register greater than zero, | to zero, BHLE, (I) 12-2 | | fraction 15-5 | BGT, (V) 11-4 | half register less than zero. | | point 15-3, 15-4 | A register less than or equal to | BHLT, (I) 12-2 | | scaling 15-3, 15-5 | zero, BLE, (V) 11-4 | half register not equal to zero,<br>BHNE, (I) 12–2 | | to decimal conversion, XBTD, | A register less than zero, BLT, (V) 11–4 | L register equal to zero, BLEQ, | | (I) 12–5<br>BIX, increment X and branch if not | A register not equal to zero, | (V) 11-4 | | zero, (V) 11-4 | BNE, (V) 11-4 | L register greater than or equa | | BIY, increment Y and branch if not | C-bit reset (equals zero), BCR, | to zero, BLGE, (V) 11-4 | | zero, (V) 11-4 | (V) 11-3 | L register greater than zero, | | BLE, branch if A register less than | C-bit reset, BCR, (I) 12–3 | BLGT, (V) 11-4 | | or equal to zero, (V) 11-4 | C-bit set, BCS, (I) 12-3 | L register less than or equal to | | BLEQ, branch if L register equal to | C-bit set, BCS, (V) 11-3 | zero, BLLE, (V) 11-4<br>L register less than zero, BLLT | | zero, (V) 11-4 | condition code equal, BCEQ, | (V) 11-4 | | BLGE, branch if L register greater | (V) 11–2 condition code equal, BCEQ, | L register not equal to zero, | | than or equal to zero -<br>(V) 11-4 | (I) 12-3 | BLNE, (V) 11-4 | | BLGT, branch if L register greater | condition code greater than or | L-bit reset, BLR, (V) 11-3 | | than zero, (V) 11-4 | equal BCGE, (V) 11-2 | L-bit reset, BLR, (I) 12-3 | | BLLE, branch if L register less than | condition code greater than or | L-bit set, BLS, (V) 11-3 | | or equal to zero, (V) 11-4 | equal, BCGE, (I) 12–3 | L-bit set, BLS, (I) 12-3 | | BLLT, branch if L register less than | condition code greater than, | magnitude is equal to zero, | | zero, (V) 11-4 | BCGT, (V) 11-2 | BMEQ, (I) 12-3 | | BLNE, branch if L register not | condition code greater than, | magnitude is equal to zero,<br>BMEQ, (V) 11–3 | | equal to zero, (V) 11-4 | BCGT, (I) 12-3 | magnitude is greater than or | | Block allocation 16–20 BLR, branch if L-bit reset, (I) 12–3 | condition code less than or<br>equal, BCLE, (V) 11–2 | equal to zero, BMGE, | | BLR, branch if L-bit reset, | condition code less than or | (I) 12–3 | | (V) 11-3 | equal, BCLE, (I) 12-3 | magnitude is greater than or | | BLS, branch if L-bit set, (I) 12-3 | condition code less than BCLT, | equal to zero, BMGE, | | BLS, branch if L-bit set, (V) 11-3 | (V) 11-2 | (V) 11-3 | | BLT, branch if A register less than | condition code less than, BCLT, | magnitude is greater than zero | | zero, (V) 11-4 | (I) 12–3 | BMGT, (I) 12–3 | | magnitude is greater than zero, | CAS (SRV) 11-23 | Comments, PMA 14-4 | |-----------------------------------------------------|-------------------------------------------------------------|------------------------------------------------------------------| | BMGT, (V) 11–3<br>magnitude is less than or equal | CAZ (SRV) 11-23<br>CEA (SRV) 11-44 | COMMON | | to zero, BMLE, (I) 12-3 | CENT pseudo-operation 16-14 | block descriptions in R-mode<br>load maps 4–4 | | magnitude is less than or equal | CGT (I) 12-3 | blocks 5-6 | | to zero, BMLE, (V) 11-3 | CGT (V) 11-4 | blocks, SEG load map | | magnitude is less than zero, | CH (I) 12-10 | entry 5-6 | | BMLT, (I) 12–3<br>magnitude is less than zero, | Change signs, CHS, (I) 12-10 | data area 15-8 | | BMLT, (V) 11-3 | Change sign, CHS, (SRV) 11–23<br>CHAR (V) 11–5 | locating with SEG 5–8<br>COMOUTPUT files 7–2 | | magnitude is not equal to zero, | CHAR (I) 12-3 | Compare | | BMNE, (I) 12–3 | Character 9–14 | A with skip, CAZ, (SRV) 11-23 | | magnitude is not equal to zero, | operations, CHAR (V) 11-5 | A with zero, CAZ, (SRV) 11-23 | | BMNE, (V) 11–3<br>register bit reset, BRBR, | (ASCII) constants 15–5<br>edit, ZED, (I) 12–4 | character field, ZCM, (I) 12-4<br>character field, ZCM, (V) 11-5 | | (I) 12-2 | operations, CHAR (I) $12-3$ | character field, ZCM, (V) 11-5<br>CLS, (V) 11-23 | | register bit set, BRBS, (I) 12-2 | CHS (I) 12-10 | fullword, C, (I) 12–10 | | register equals zero, BREQ, | CHS (SRV) 11-23 | halfword, CH, (I) 12–10 | | (I) 12–2<br>register greater than or equal to | Class bits in R-mode long reach | Complement | | zero, BRGE, (I) 12-2 | instruction format 10–7<br>Class bits in R-mode stack | A, CMA, (SRV) 11-32<br>Complement half register, CMH, | | register greater than zero, | instruction format 10-6, 10-7 | (I) 12–15 | | BRGT, (I) 12-2 | Clear | Complement register, CMR, | | register less than zero, BRLT, | A left byte, CAL, (SRV) 11-7 | (I) 12-15 | | (I) 12–2<br>register less than or equal to | A right byte, CAR, (SRV) 11–7<br>A register, CRA (SRV) 11–7 | Complement, FCM, (RV) 11–19<br>Compute effective address, CEA, | | zero, BRLE, (I) 12-2 | active interrupt, CAI, (I) 12-14 | (SRV) 11-44 | | register not equal to zero, | active interrupt, CAI, | Computed GOTO, CGT, (I) 12–3 | | BRNE, (I) 12-2 | (SRV) 11-29 | Computed GOTO, CGT, (V) 11-4 | | Branch, BRAN (I) 12-1 | B register, CRB (SRV) 11-8 | Concordance (cross | | Branch, BRAN, (V) 11-2<br>BRBR (I) 12-2 | E, CRE, (V) 11–8<br>high byte 1 left, CRBI, (I) 12–4 | reference) 3–1, 3–5<br>Condition code bits 9–14 | | BRBS (I) 12–2 | high byte 1 left, GRB1, (1) 12-4 | Condition code test 11–33 | | BRD1 (I) 12-3 | (I) 12–4 | Conditional assembly 17-6 | | BRD2 (I) 12-3 | L and E, CRLE, (V) 11-8 | Conditional assembly pseudo- | | BRD4 (I) 12–3<br>BREQ (I) 12–2 | left halfword, CRHL, (I) 12-5 | operations, CA 16-1 | | BRGE (I) 12-2 | long, CRL, (SRV) 11–8<br>machine check, RMC, | Constant expressions 18–5, 18–6<br>Constants 15–1, 15–8, 18–5 | | BRGT (I) 12-2 | (I) 12-14 | integer 15–1 | | BRI1 (I) 12–3 | machine check, RMC, | numeric 15-1, 15-2 | | BRI2 (I) 12-3 | (SRV) 11-28 | PMA 14-4 | | BRI4 (I) 12–3<br>Bringing a program into | register and memory, CLEAR<br>[I] 12–4 | Control extended control store,<br>CXCS, (I) 12–17 | | memory 6-1 | register, CLEAR (V) 11-7 | Control extended control store, | | BRLE (I) 12-2 | register, CR, (I) 12-4 | CXCS, (V) 11-34 | | BRLT (I) 12-2 | right halfword, CRHR, (I) 12-5 | Control word format 11-10 | | BRNE (I) 12–2<br>BSS pseudo-operation 16–20 | Clear (V) 11-7 | Conventions | | BSZ pseudo-operation 16-20 | Clear (I) 12-4<br>Clearing memory with | filename 2–1<br>instruction summary and | | 1 | FILMEM 4–1 | description 2-2 | | C | CLS (V) 11-23 | Prime 2-1 | | C, compare fullword, (I) 12–10<br>C-bit 9–14 | CMA (SRV) 11–32 | sign 15-9 | | C64R, check 64R pseudo- | CMDNC0, command UFD 6-2<br>CMH (I) 12-15 | space 15–9<br>text 2–1 | | operation 16-5 | CMR (I) 12-15 | Convert | | CA, conditional assembly pseudo- | Colon, assembler notation 15-10 | 31-bit integer to float, FLOT, | | operations 16-1 | COMM pseudo-operation 15-8 | (R) 11-19 | | CAI (I) 12-14<br>CAI (SRV) 11-29 | COMM, FORTRAN compatible | binary to decimal, XBTD, | | CAL (SRV) 11-7 | COMMON pseudo-<br>operation 16–20 | (V) 11–11<br>float to integer, INT, (V) 11–21 | | CALF stack frame header 9–5 | Command files, loader | float to integer, INTA, | | CALF (I) 12–20 | subcommands in 4-1 | (V) 11-21 | | Call conventions (SR) 8-2 Call conventions (VI) 8-3 | Command line | float to long integer, INTL, | | Call fault handler, CALF, | format 18–4<br>operands 18–5 | (V) 11–22<br>floating point to halfword | | (I) 12–20 | options, PMA 3-1 | integer, INTH, (I) 12-8 | | CALL macro 17-1, 17-2 | Command summary, SEG 5-8 | floating point to integer, INT, | | Call recursive entry procedure, | Command UFD, CMDNC0 6-2 | (I) 12-8 | | CREP, (R) 11-44<br>CALL pseudo-operation 16-18 | Command UFD, installation in the 6–2 | halfword integer to floating | | CAR (SRV) 11-7 | Commands, SEG level 5-9 | point, FLTH, (I) 12–7<br>integer to float, FLTA, | | | • | | | (V) 11-20 | DEC pseudo-operation 16-10 | DFM (I) 12–9 | |---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | integer to floating point, FLT, | DECI 11-8, 12-5 | DFMP (RV) 11–18 | | (I) 12-7 | Decimal 9-2, 9-14, 18-5 | DFS (I) 12-9 | | long integer to float, FLTL, | add, XAD, (I) 12-5 | DFSB (RV) 11–18 | | (V) 11-20 | add, XAD, (V) 11–10 | DFST (I) 12-9 | | single to double float, FDBL, | arithmetic, DEC 11-8 | DFST (RV) 11-18 | | (V) 11–19 | arithmetic, DECI (I) 12–5 | DFTB pseudo-operation 16-8 | | single to double, DBLE, | compare, XCM, (I) 12-5 | DFVT pseudo-operation 16-8 | | (I) 12-8 | compare, XCM, (V) 11–11 | DH (I) 12-10 | | Copy sign of A, CSA, (SRV) 11–24 | constants 15-1 | DH1 (I) 12–11 | | Copy sign, CSR, (I) 12-10 | constants, fixed point 15–3 | DH2 (I) 12-11 | | CR (I) 12-4 | constants, floating point 15–5 | Direct entry calls 5-6 | | CRA (SRV) 11-7 | control word format (VI) 9–2 | Direct entry links, SEG load map | | CRB (SRV) 11-8 | data types 11–8 | entry 5-6 | | CRBI (I) 12–4 | divide, XDV, (I) 12–5 | Displacement field meaning | | CRBR (I) 12–4 | divide, XDV, (V) 11-12 | base register relative 10-6 | | CRE (V) 11-8 | exception (CEX) 11–10 | basic format 10–4 | | Creating a system command 6–2 | exponent 15-5 | procedure relative | | CREP (R) 11-44 | fraction 15–5 | format 10-5 | | CRHL (I) 12–5 | integer 15–5 | sector relative format 10-4 | | CRHR (I) 12–5 | move, XMV, (I) 12-5 | two word memory reference | | CRL (SRV) 11-8 | move, XMV, (V) 11-14 | (V-mode) 10-8 | | CRLE (V) 11-8 | multiply, XMP, (I) 12–5 | DIV (SR) 11-24 | | Cross-reference listing | multiply, XMP, (V) 11-13 | DIV (V) 11-24 | | (concordance) 3-5 | Decimal to binary conversion, | Divide | | CSA (SRV) 11-24 | XCTB, (I) 12-5 | fullword, D, (I) 12-10 | | CSR (I) 12-10 | Decimal to binary conversion, | halfword, DH, (l) 12-10 | | CXCS (I) 12-17 | XCTB, (V) 11-12 | long, DVL, (V) 11-25 | | CXCS (V) 11-34 | Declare stack relative pseudo- | Divide, DIV, (SR) 11-24 | | n | operation, DYNM 16-21 | Divide, DIV, (V) 11-24 | | D | Decrement | DLD (SR) 11-39 | | D (I) 12-10 | and replace X, DRX, | DM (I) 12-11 | | D16S pseudo-operation 16-14 | (SRV) 11-53 | DMH (I) 12-11 | | D32I pseudo-operation 16-14 | half register by 1, DH1, | Double add, DAD, (SR) 11-24 | | D32R pseudo-operation 16-14 | (I) 12-11 | Double asterisk (initial zero) | | D32S pseudo-operation 16-14 | half register by 2 and branch, | PMA 14-6 | | D64R, R-mode load | BHD2, (I) 12–3 | Double floating | | command 4-10 | half register by 2, DH2, | add, DFA, (I) 12-8 | | D64R pseudo-operation 16-14 | (I) 12-11 | compare, DFC, (I) 12-8<br>complement, DFCM, (I) 12-9 | | D64V pseudo-operation 16-14 | half register by 4 and branch, | divide, DFD, (I) 12-9 | | DAC pseudo-operation 16-7 | BHD4, (I) 12-3 | load, DFL, (I) 12-9 | | DAD (SRV) 11-24 | memory fullword, DM,<br>(I) 12–11 | multiply, DFM, (I) 12-9 | | Data 15 1 | memory halfword, DMH, | store, CFST, (I) 12-9 | | constants 15–1<br>definition pseudo-operations, | (I) 12–11 | subtract, DFS, (I) 12-9 | | DD 16-1 | register by 1 and branch, BRD1, | Double load, DLD, (SR) 11-39 | | structures, mode usage 2–4 | (I) 12–3 | Double precision 15-1 | | structures, mode usage 2-4 structures, useful in | register by 1, DR1, (I) 12-11 | 64 bits, floating point 9–2 | | debugging 7-1 | register by 2 and branch, BRD2, | floating add, CFAD, | | types, decimal 11-8 | (I) 12–3 | (RV) 11-17 | | DATA pseudo-operation 16-10 | register by 2, DR2, (I) 12-11 | floating complement, DFCM, | | DBL (SRV) 11-24 | register by 4 and branch, BRD4, | (RV) 11-17 | | DBLE (I) 12-8 | (I) 12-3 | floating divide, DFDV, | | DD, data definition pseudo- | X and branch if not zero, BDX, | (RV) 11-17 | | operations 16-1 | (V) 11-4 | floating load index, DFLX, | | DDM pseudo-operation 16-14 | Y and branch if not zero, BDY, | (V) 11-18 | | Debugging 7-1 | (V) 11-4 | floating load, DFLD, | | access violation message 7-1 | | | | | Definition, macro 17-1, 17-2, 17-4 | (RV) 11-18 | | advanced techniques 7-2 | | (RV) 11–18<br>floating multiply, DFMP, | | | Definition, macro 17–1, 17–2, 17–4<br>Deleting SEG runfiles 5–7<br>DEX, decimal exception 11–10 | floating multiply, DFMP,<br>(RV) 11-18 | | floating exception (FLEX) 7–1 illegal Segno message 7–1 | Deleting SEG runfiles 5–7 | floating multiply, DFMP,<br>(RV) 11–18<br>floating point 15–5 | | floating exception (FLEX) 7-1<br>illegal Segno message 7-1<br>interactive programs 18-1 | Deleting SEG runfiles 5–7<br>DEX, decimal exception 11–10 | floating multiply, DFMP,<br>(RV) 11–18<br>floating point 15–5<br>floating point compare and | | floating exception (FLEX) 7-1<br>illegal Segno message 7-1<br>interactive programs 18-1 | Deleting SEG runfiles 5–7<br>DEX, decimal exception 11–10<br>DFA (I) 12–8 | floating multiply, DFMP,<br>(RV) 11–18<br>floating point 15–5<br>floating point compare and<br>skip, DFCS, (RV) 11–17 | | floating exception (FLEX) 7-1 illegal Segno message 7-1 interactive programs 18-1 MO-memory overflow 7-1 no vector message 7-1 | Deleting SEG runfiles 5-7 DEX, decimal exception 11-10 DFA (I) 12-8 DFAD (RV) 11-17 DFC (I) 12-8 DFCM (I) 12-9 | floating multiply, DFMP, (RV) 11–18 floating point 15–5 floating point compare and skip, DFCS, (RV) 11–17 floating point register 9–12 | | floating exception (FLEX) 7-1 illegal Segno message 7-1 interactive programs 18-1 MO-memory overflow 7-1 no vector message 7-1 pointer fault message 7-1 | Deleting SEG runfiles 5-7 DEX, decimal exception 11-10 DFA (I) 12-8 DFAD (RV) 11-17 DFC (I) 12-8 DFCM (I) 12-9 DFCM (RV) 11-17 | floating multiply, DFMP, (RV) 11-18 floating point 15-5 floating point compare and skip, DFCS, (RV) 11-17 floating point register 9-12 floating store, DFSB, | | floating exception (FLEX) 7-1 illegal Segno message 7-1 interactive programs 18-1 MO-memory overflow 7-1 no vector message 7-1 pointer fault message 7-1 PRIMOS severe errors 7-2 | Deleting SEG runfiles 5-7 DEX, decimal exception 11-10 DFA (I) 12-8 DFAD (RV) 11-17 DFC (I) 12-8 DFCM (II) 12-9 DFCM (RV) 11-17 DFCS (RV) 11-17 | floating multiply, DFMP, (RV) 11-18 floating point 15-5 floating point compare and skip, DFCS, (RV) 11-17 floating point register 9-12 floating store, DFSB, (RV) 11-18 | | floating exception (FLEX) 7-1 illegal Segno message 7-1 interactive programs 18-1 MO-memory overflow 7-1 no vector message 7-1 pointer fault message 7-1 PRIMOS severe errors 7-2 severe PRIMOS errors 7-1 | Deleting SEG runfiles 5-7 DEX, decimal exception 11-10 DFA (I) 12-8 DFAD (RV) 11-17 DFC (I) 12-8 DFCM (I) 12-9 DFCM (RV) 11-17 DFCS (RV) 11-17 DFCS (RV) 11-17 DFD (I) 12-9 | floating multiply, DFMP, (RV) 11-18 floating point 15-5 floating point compare and skip, DFCS, (RV) 11-17 floating point register 9-12 floating store, DFSB, (RV) 11-18 floating subtract, DFSB, | | floating exception (FLEX) 7-1 illegal Segno message 7-1 interactive programs 18-1 MO-memory overflow 7-1 no vector message 7-1 pointer fault message 7-1 PRIMOS severe errors 7-2 severe PRIMOS errors 7-1 stack overflow 7-1 | Deleting SEG runfiles 5-7 DEX, decimal exception 11-10 DFA (I) 12-8 DFAD (RV) 11-17 DFC (I) 12-8 DFCM (I) 12-9 DFCM (RV) 11-17 DFCS (RV) 11-17 DFD (I) 12-9 DFDV (RV) 11-17 | floating multiply, DFMP, (RV) 11-18 floating point 15-5 floating point compare and skip, DFCS, (RV) 11-17 floating point register 9-12 floating store, DFSB, (RV) 11-18 floating subtract, DFSB, (RV) 11-18 | | floating exception (FLEX) 7-1 illegal Segno message 7-1 interactive programs 18-1 MO-memory overflow 7-1 no vector message 7-1 pointer fault message 7-1 PRIMOS severe errors 7-2 severe PRIMOS errors 7-1 stack overflow 7-1 using COMOUTPUT files 7-1 | Deleting SEG runfiles 5-7 DEX, decimal exception 11-10 DFA (I) 12-8 DFAD (RV) 11-17 DFC (I) 12-8 DFCM (I) 12-9 DFCM (RV) 11-17 DFCS (RV) 11-17 DFD (I) 12-9 DFDV (RV) 11-17 DFD (I) 12-9 DFDV (RV) 11-17 | floating multiply, DFMP, (RV) 11-18 floating point 15-5 floating point compare and skip, DFCS, (RV) 11-17 floating point register 9-12 floating store, DFSB, (RV) 11-18 floating subtract, DFSB, (RV) 11-18 Double subtract, DSB, | | floating exception (FLEX) 7-1 illegal Segno message 7-1 interactive programs 18-1 MO-memory overflow 7-1 no vector message 7-1 pointer fault message 7-1 PRIMOS severe errors 7-2 severe PRIMOS errors 7-1 stack overflow 7-1 | Deleting SEG runfiles 5-7 DEX, decimal exception 11-10 DFA (I) 12-8 DFAD (RV) 11-17 DFC (I) 12-8 DFCM (I) 12-9 DFCM (RV) 11-17 DFCS (RV) 11-17 DFD (I) 12-9 DFDV (RV) 11-17 | floating multiply, DFMP, (RV) 11-18 floating point 15-5 floating point compare and skip, DFCS, (RV) 11-17 floating point register 9-12 floating store, DFSB, (RV) 11-18 floating subtract, DFSB, (RV) 11-18 | | DR2 (I) 12-11 | ENDM pseudo-operation 16-16, | Exception codes, floating | |----------------------------------------------------------|----------------------------------------------------------|-------------------------------------------------------| | DRX (SRV) 11–53<br>DSB (SR) 11–24 | 17-2 | point 11-6 | | DUII pseudo-operation 16-15 | ENT pseudo-operation 16–20<br>Enter | Exceptions, floating point 11-16, 12-6 | | Dummy instruction, triple asterisk, | 16S mode, E16S, (SRV) 11-1 | Excess-128 notation 15-5 | | PMA 14-5 | 16S mode, E16S, (I) 12-1 | Exchange and clear the A register, | | Dummy words 17–1, 17–2, 17–4<br>DVL (V) 11–25 | 32I mode, E32I, (I) 12–1<br>32I mode, E32I, (SRV) 11–1 | XCA, (SRV) 11-43 | | DYNM pseudo-operation 15-8, | 32R mode, E32R, (I) 12-1 | Exchange and clear the B register, XCB, (SRV) 11–43 | | 16-21 | 32R mode, E32R, (SRV) 11-1 | Exclamation mark, assembler | | DYNT pseudo-operation 16-19 | 32S mode, E32S, (I) 12-1<br>32S mode, E32S, (SRV) 11-1 | notation 15–10 | | E | 64R mode, E64R, (I) 12-1 | Exclusive OR<br>fullword, X, (I) 12–15 | | E16S (I) 12-1 | 64R mode, E64R, (SRV) 11-1 | halfword, XH, (I) 12-16 | | E16S (SRV) 11-1<br>E32I (I) 12-1 | 64V mode, E64V, (I) 12-1 | long, ERL, (V) 11–32 | | E32I (SRV) 11-1 | 64V mode, E64V, (SRV) 11–1<br>double precision mode-DBL, | to A, ERA, (SRV) 11-32<br>Execute I/O, EIO, (I) 12-14 | | E32R (I) 12-1 | (SR) 11-24 | Execute I/O, EIO, (V) 11-29 | | E32R (SRV) 11-1 | loader mode pseudo-operation, | Execute, XEC, (RV) 11-49 | | E32S (I) 12-1<br>E32S (SRV) 11-1 | ELM 16–15<br>machine check mode, EMCM, | Executing PMA programs 6-1 Execution of segmented | | E64R (I) 12-1 | (I) 12–14 | runfiles 6-2 | | E64R (SRV) 11-1 | machine check mode, EMCM, | Execution of unsegmented | | E64V (I) 12-1<br>E64V (SRV) 11-1 | (SRV) 11–28 paging mode and jump (Prime | runfiles 6-1 | | EAA (R) 11-44 | 300), EPMJ, (R) 11-34 | Exponent<br>binary 15–5 | | EAFA (I) 12-6 | paging mode and jump to XCS | decimal 15-5 | | EAFA (V) 11-15<br>EAL (V) 11-44 | (Prime 300), EPMX, | Expressions 15-1, 15-5, 15-8, | | EALB (V) 11-44<br>EALB (V) 11-45 | (SR) 11–34<br>R-mode recursive procedure | 15–10, 18–5<br>constant 18–5 | | EALB (I) 12-19 | stack, ENTR, (R) 11-45 | PMA 14-4 | | EAR (I) 12-19 | restricted execution mode and | EXT pseudo-operation 15-8, | | EAXB (I) 12-20<br>EAXB (V) 11-45 | jump to XCS (Prime 300),<br>ERMX, (SR) 11–35 | 16–19 | | ECB | single precision mode, SGL, | F | | description in load map 5-6 | (SR) 11-27 | FA (I) 12-6 | | entry control block 9–6<br>pseudo-operation 16–19 | standard interrupt mode, ESIM,<br>(SRV) 11–30 | FAD (R) 11-18 | | Edit | standard interrupt mode, ESIM, | FAIL pseudo-operation 16–9<br>Fault pointers 5–6 | | character field, ZED, (V) 11-5 | (I) 12–14 | FC (I) 12-7 | | program word 11-6<br>sub-operations 11-14 | vector interrupt mode, EVIM,<br>(I) 12–14 | FCM (RV) 11-19 | | Effective address formation 10-1 | vectored interrupt mode, | FCM (I) 12–7<br>FCS (RV) 11–19 | | Effective address formation (PSD | EVIM, (SRV) 11-30 | FD (I) 12-7 | | and VPSD only) 18–4<br>Effective address to | virtual mode and jump (Prime<br>300), EVMJ, (SR) 11–35 | FDBL (V) 11-19 | | A register, EAA, (R) 11-44 | virtual mode and jump (Prime | FDV (RV) 11–19<br>Field address and length | | field address register, EAFA, | 300), EVMX, (SR) 11-35 | registers 9–12 | | (V) 11–15<br>L register, EAL, (V) 11–44 | ENTR (R) 11-45 | Field operations, FIELD, (I) 12-5 | | link base, EALB, (I) 12–19 | Entry control block, ECB 9-6<br>EPMJ (SR) 11-34 | Field operations, FIELD,<br>(V) 11–15 | | link base, EALB, (V) 11-45 | EPMX (SR) 11-34 | FIELD (I) 12–5 | | register, EAR, (I) 12–19<br>temporary base, EAXB, | EQU pseudo-operation 16-21 | FIELD (V) 11–15 | | (I) 12-20 | Equals sign (literals) 14–6<br>ERA (SRV) 11–32 | File types, PMA 3-1 Filename conventions 2-1 | | XB, EAXB, (V) 11-45 | ERL (V) 11-32 | Fill character field, ZFH, (I) 12-4 | | EIO (I) 12–14<br>EIO (V) 11–29 | ERMX (SR) 11-35 | Fill field, ZFIL, (V) 11-6 | | EJCT pseudo-operation 16-11 | Error messages<br>PMA 7-1 | FILMEM, PRIMOS clear memory command 4-1 | | Elements of PMA 14–4 | run-time 6–5 | FIN pseudo-operation 16–12 | | ELM pseudo-operation 16–15<br>ELSE pseudo-operation 16–8 | Errors (system), SEG's action 5-1 | FIN, use of 15-10 | | EMCM (I) 12–14 | Escape character assembler notation 15–10 | Fixed point decimal | | EMCM (SRV) 11–28 | ESIM (I) 12-14 | constants 15-3, 15-4<br>FL (I) 12-7 | | Enable interrupts, ENB, | ESIM (SRV) 11-30 | FLD (RV) 11–19 | | (SRV) 11–30<br>Enable interrupts, ENB, (I) 12–14 | pseudo-operation 16-5<br>EVIM (I) 12-14 | Floating | | ENB (SRV) 11–30 | EVIM (SRV) 11–30 | add, FA, (I) 12–6<br>add, FAD, (RV) 11–18 | | ENB (I) 12-14 END provide approximation 10.5 | EVMJ (SR) 11-35 | compare and skip, FCS, | | END pseudo-operation 16–5<br>ENDC pseudo-operation 16–9 | EVMX (SR) 11-35<br>Examples, PMA 14-9 | (RV) 11–19 | | = - pooddo oporation 10-0 | DAGIII PICO, I WILL 14-9 | compare, FC, (I) 12-7 | | complement, FCM, (I) 12-7 | FSZE (RV) 11-21 | BRB5 12-2 | |--------------------------------------|------------------------------------------------|------------------------| | divide, FD, (I) 12-7 | FTNLIB library, use with SEG 5-3 | BRD1 12-3 | | divide, FDV, (RV) 11-19 | FTNLIB, system library 8–1 | BRD2 12-3 | | load index, FLX, (RV) 11-20 | C | BRD4 12-3 | | load, FL, (I) 12-7 | G | BREQ 12-2 | | load, FLD, (RV) 11-19 | General data structures, mode | BRGE 12–2<br>BRGT 12–2 | | multiply, FM, (I) 12-7 | usage 2-4 | | | multiply, FMP, (RV) 11-20 | General registers, 32 bits 9-10 | BRI1 12-3 | | point arithmetic, FLPT (I) 12-6 | Generic | BRI2 12-3 | | point arithmetic, FLPT | AP instruction formats 9-16 | BRI4 12–3<br>BRLE 12–2 | | (V) 11–16 | instruction formats 9-14 | BRLT 12-2 | | point decimal constants 15-5 | non-register instruction | BRNE 12-2 | | point exception codes 11-16 | formats 9-17 | C 12-10 | | point exceptions 11-16, 12-6 | register instruction | CAI 12-14 | | point mantissa and exponent | formats 9–17 | CALF 12-20 | | ranges 11-17 | GO pseudo-operation 16–9 | CGT 12-3 | | point register, double | H | CH 12-10 | | precision 9-12 | | CHS 12-10 | | point register, single precision, | Halt, HLT, (I) 12-17 | CMH 12-15 | | (RVI) 9-10 | Halt, HLT, (SRV) 11-35 | CMR 12-15 | | point registers, 9-12 | Header, stack segment 9-4 | CR 12-4 | | point, double precision 15-5 | HEX pseudo-operation 16–11<br>Hexadecimal 18–5 | CRBI 12-4 | | point, double precision 64 | | CRBR 12-4 | | bits 9-2 | Hexadecimal constants 15-2 | CRHL 12-5 | | point, single precision 15–5 | HLT, halt, (I) 12-17 | CRHR 12-5 | | round, FRN, (I) 12-7 | HLT, halt, (SRV) 11–35<br>HPSD 18–3 | CSR 12-10 | | skip if greater than zero, FSCT, | UL2D 10-2 | CXCS 12-17 | | (RV) 11-20 | I | D 12-10 | | skip if less than or equal to zero, | I-mode instructions | DBLE 12-8 | | FSLE, (RV) 11-20 | A 12-9 | DFA 12-8 | | skip if minus, FSMI, | ABQ 12-21 | DFC 12-8 | | (RV) 11-21 | ADLR 12-10 | DFCM 12-9 | | skip if not zero-FSNZ,<br>(RV) 11–21 | AH 12-10 | DFD 12-9 | | skip if plus, FSPL, (RV) 11-21 | ARFA 12-5 | DFL 12-9 | | skip if zero, FSZE, (RV) 11-21 | ARGT 12-20 | DFM 12-9 | | store, FST, (I) 12-8 | ATQ 12-21 | DFS 12-9 | | store, FST, (RV) 11-21 | BCEQ 12-3 | DFST 12-9 | | subtract, FS, (I) 12-8 | BCGE 12-3 | DH 12-10 | | subtract, FSB, (RV) 11-20 | BCGT 12-3 | DH1 12-11 | | LOT (R) 11-19 | BCLE 12-3 | DH2 12-11 | | LPL (RV) 11–21 | BCLT 12-3 | DM 12-11 | | LPT, floating point | BCNE 12-3 | DMH 12-11 | | arithmetic 11-16, 12-6 | BCR 12-3 | DR2 12-11 | | FLT (I) 12-7 | BCS 12-3 | DR1 12-11 | | ELTA (V) 11–20 | BFEQ 12-2 | E16S 12-1 | | FLTH (I) 12-7 | BFGE 12-2 | E32I 12-1 | | FLTL (V) 11-20 | BFGT 12-2 | E32R 12-1 | | FLX (RV) 11-20 | BFLE 12+2 | E32S 12-1 | | FM (I) 12–7 | BFLT 12-2 | E64R 12-1 | | FMP (RV) 11-20 | BFNE 12-2 | E64V 12-1 | | Force loading 4–6 | BHD1 12-3 | EAFA 12-6 | | Format specifier 18-4 | BHD2 12-3 | EALB 12-19 | | Formats | BHD4 12-3 | EAR 12-19 | | assembler (I-mode), | BHGE 12-2 | EAXB 12-20 | | PMA 14-7 | BHGT 12-2 | EIO 12-14 | | assembler, PMA 14-7 | BHIL 12-3 | EMCM 12-14 | | instruction 9–14 | BHI2 12–3 | ENB 12-14 | | instruction, PMA 14-6 | BHI4 12-3 | ESIM 12-14 | | FORTRAN libraries 8–1 | BHLE 12-2 | EVIM 12-14 | | Fraction, binary 15–5 | BHLT 12-2 | FA 12-6 | | FRN (I) 12-7 | BHNE 12-2 | FC 12-7 | | FRN (RV) 11-20 | BLR 12-3 | FCM 12-7 | | FS (I) 12-8 | BLS 12-3 | FD 12-7 | | FSB (RV) 11-20 | BMGE 12-3 | FL 12-7 | | FSCT (RV) 11-20 | BMGT 12-3 | FLT 12-7 | | FSLE (RV) 11-20 | BMLE 12-3 | FLTH 12-7<br>FM | | FSMI (RV) 11-21 | BMLT 12-3 | FRN 12-7 | | FSNZ (RV) 11-21 | BMNE 12-3 | FS 12 8 | | FST (I) 12-8 | BMEQ 12-3 | FST 12-8 | | FST (RV) 11-21 | BRBR 12-2 | 101 12-0 | | HLT 12-17 | MDWC 12-14 | ZFH 12-4 | |---------------------------------------------------|--------------------------------------------------|-----------------------------------------------------------------------------------------------------------------| | _ | MH 12-12 | ZM 12-5 | | I 12–17 | | | | ICBL 12–17 | N 12–15 | ZMH 12-5 | | ICBL 12-18 | NFYB 12-20 | ZMV 12-4 | | IBCR 12-17 | NFYE 12-20 | ZMVD 12-4 | | ICHR 12-18 | NH 12-15 | ZTRN 12-4 | | | | | | IH 12–18 | NOP 12-17 | I-mode | | IH2 12-11 | O 12–15 | instruction formats 9–16 | | IH1 12-11 | OH 12-15 | PMA 14-6 | | | OTK 12-14 | | | IM 12-12 | | purpose 9-16 | | IMH 12-12 | PCL 12-20 | I/O 9–14 | | INBN 12-20 | PID 12-12 | input/output (I) 12–14 | | INEC 12-20 | PIDH 12-12 | input/output (V) 11-29 | | INEN 12-20 | PIM 12-13 | IAB (SRV) 11-40 | | | | | | INH 12-14 | PIMH 12–13 | ICA (SRV) 11-40 | | INK 12–14 | PRTN 12–20 | ICBL (I) 12–17 | | INT 12-8 | PTLB 12-17 | ICBL (I) 12–18 | | INTH 12-8 | RBQ 12-21 | ICBR (Í) 12–17 | | | • | | | IR1 12–12 | RCB 12–15 | ICHR (I) 12–18 | | IR2 12–12 | RMC 12–14 | ICL (SRV) 11–40 | | IRB 12-18 | ROT 12-21 | ICR (SRV) 11-40 | | IRH 12-18 | RRST 12-17 | IF pseudo-operation 16-9 | | | | | | IRTC 12–14 | RSAV 12–17 | If (SRV) 11–34 | | IRTN 12-14 | RTQ 12–21 | IFTNLB library, use with SEG 5-2 | | ITLB 12-17 | S 12-13 | IFTNLB, system library 8-1 | | JMP 12-20 | SCB 12-15 | IFTT pseudo-operation 16-9 | | • | | | | JSR 12–20 | SH 12–13 | IFVF pseudo-operation 16-9 | | JSXB 12-20 | SHA 12-22 | IFVT pseudo-operation 16–9 | | L 12–18 | SHL 12-23 | IFX pseudo-operation 16–9 | | LCEQ 12-16 | SHL 12-22 | IH halfword, (I) 12-18 | | • | | | | LCGE 12-16 | SHL1 12-22 | IH1 (I) 12–11 | | LCGT 12–16 | SHR1 12–23 | IH2 (I) 12–11 | | LCLE 12-16 | SHR2 12-23 | ILE (V) 11-40 | | LCLT 12-16 | SL1 12-22 | IM (I) 12–12 | | | | | | LCNE 12-16 | SL1 12-22 | IMA (SRV) 11-40 | | LDAR 12–18 | SR2 12-22 | Images saved by load 6–2 | | LDC 12-4 | SRL 12-22 | IMH (I) 12–12 | | LEG 12-16 | SSM 12-13 | Immediate | | | | | | LF 12-17 | SSP 12–13 | type 1, I-mode instruction | | LFEQ 12–16 | ST 12-19 | format 9–18 | | LFGE 12-16 | STAR 12-19 | type 2, I-mode instruction | | LFGT 12-16 | STC 12-4 | format 9–18 | | | STCD 12-19 | type 3, I-mode instruction | | LFLE 12–16 | | | | LFLI 12–6 | STCH 12–19 | format 9–18 | | LFLT 12-16 | STEX 12-20 | INA (SR) 11–30 | | LFNE 12-16 | STFA 12-6 | INBC (I) 12-20 | | LGE 12-16 | STH 12-19 | INBC (V) 11-49 | | | | . , | | LGT 12-16 | STPM 12–17 | INBC (V) 11-49 | | LH 12–18 | SVC 12-20 | INBN (I) 12–20 | | LHEQ 12-16 | TC 12-13 | Inclusive OR, ora, (V) 11-33 | | LHGE 12-16 | TCH 12-13 | Increment | | LHGT 12-16 | TFLR 12-5 | and replace X, IRX. | | | | | | LHL1 12-18 | TM 12-14 | (SRV) 11-53 | | LHL2 12-19 | TMH 12-14 | half register by 1 and branch, | | LHLE 12-16 | TSTQ 12-21 | BHIL, (I) 12-3 | | LHLT 12-16 | VIRY 12–14 | half register by 1, IH, (I) 12-11 | | | VIKI 12-14 | last register by 1, 111, (1) 12-11 | | LHNE 12-16 | WAIT 12-20 | half register by 2 and branch, | | LIOT 12-17 | WCS 12-17 | BHI2, (I) 12-3 | | LLE 12-16 | X 12-15 | half register by 2, IH1, | | LLT 12-16 | XAD 12-5 | (I) 12–11 | | LMCM 12–14 | | | | | XBTD 12-5 | memory fullword, IM, | | LNE 12–16 | XCM 12-5 | (I) 12–12 | | LPID 12-17 | XDTB 12-5 | memory halfword, IMH, | | LPSW 12-17 | XED 12-5 | (I) 12-12 | | LT 12-17 | XH 12-16 | memory replace and skip, IRS, | | | 711 14-10 | | | LWCS 12-17 | VN437 40 E | | | | XMV 12-5 | (SRV) 11–53 | | M 12–12 | XMV 12-5<br>XVRY 12-14 | register by 1 and branch, BRIL, | | | | (SRV) 11–53 register by 1 and branch, BRIL, (I) 12–3 | | M 12–12<br>MDEI 12–1 <b>4</b> | XVRY 12-14<br>XVRY 12-17 | register by 1 and branch, BRIL,<br>(I) 12–3 | | M 12–12<br>MDEI 12–14<br>MDII 12–14 | XVRY 12-14<br>XVRY 12-17<br>ZCM 12-4 | register by 1 and branch, BRIL,<br>(I) 12–3<br>register by 1, IR1, (I) 12–12 | | M 12–12<br>MDEI 12–14<br>MDII 12–14<br>MDIW 12–14 | XVRY 12-14<br>XVRY 12-17<br>ZCM 12-4<br>ZDV 12-5 | register by 1 and branch, BRIL,<br>(I) 12–3<br>register by 1, IR1, (I) 12–12<br>register by 2 and branch, BRI2, | | M 12–12<br>MDEI 12–14<br>MDII 12–14 | XVRY 12-14<br>XVRY 12-17<br>ZCM 12-4 | register by 1 and branch, BRIL,<br>(I) 12–3<br>register by 1, IR1, (I) 12–12 | | register by 2, IR2, (I) 12-12 | Integers, decimal 15–5 | JEQ (R) 11-45 | |--------------------------------------------------------------------|-------------------------------------------------|--------------------------------------------------------------| | register by 4 and branch, BRI4, | Integrity check for hardware, | JGE (R) 11-45 | | (I) 12–3<br>X and branch if not zero, BIX, | INTGY (I) 12-14 Integrity check for hardware, | JGT (R) 11-45<br>JIX (R) 11-46 | | (V) 11-4 | INTGY (V) 11-28 | JLE (R) 11–46 | | Y and branch if not zero, BIY, | Interactive debugging | JLT (R) 11–46 | | (V) 11-4 | programs 18-1 | JMP (I) 12–20 | | Index registers 9–17, 18–4 | Interchange | JMP (SRV) 11-46 | | Indexing 10–2<br>Indexing, PMA 14–5 | and clear left, ICL,<br>(SRV) 11–40 | JNE (R) 11-46<br>JSR (I) 12-20 | | Indirect | and clear right, ICR, | JST (SRV) 11-46 | | links, 32R vs. 64R 4-5 | (SRV) 11-40 | JSX (RV) 11-47 | | pointer pseudo-operation, | A and B registers, IAB, | JSXB (I) 12-20 | | IP 16-7<br>pointer, three word memory | (SRV) 11-40 | JSXB (V) 11-47<br>JSY (V) 11-47 | | reference 9-3 | bytes and clear left, ICBL,<br>(I) 12–17 | Jump and | | pointer, two word memory | bytes and clear right, ICBR, | decrement X, JCX, (R) 11-45 | | reference 9-3 | (I) 12–17 | increment X, JIX, (R) 11-46 | | word, one word memory | halfwords and clear left, ICBL, | set XB, JSXB, (I) 12-20 | | reference 9-3<br>Indirection 10-2 | (I) 12–18<br>L and E, ILE, (V) 11–40 | set XB, JSXB, (V) 11–47<br>set Y, JSY, (V) 11–47 | | Indirection, PMA 14–5 | memory and the A register, | store return in X, JSX, | | INEC (I) 12-20 | IMA, (SRV) 11-40 | (RV) 11–47 | | INEC (V) 11-49 | register and memory, fullword, | store, JST, (SRV) 11-46 | | INEN (I) 12-20 | I, (I) 12–17 | Jump if | | INEN (V) 11-49<br>INH (I) 12-14 | register and memory, halfword,<br>IH, (I) 12–18 | equal to zero, JEQ, (R) 11–45 greater than or equal to zero, | | INH (SRV) 11–30 | register bytes, IRB, (I) 12-18 | JGE, (R) 11-45 | | Inhibit interrupts, INH, | register halfwords and clear | greater than zero, JGT, | | (SRV) 11-30 | right, ICHR, (I) 12-18 | (R) 11-45 | | Inhibit interrupts, INH, (I) 12–14 | register halves, IRH, (I) 12-18 | less than or equal to zero, JLE, | | INK (I) 12-14<br>INK (SRV) 11-31 | Interfacing with the system libraries 8–1 | (R) 11-46<br>less than zero, JLT, (R) 11-46 | | Input keys, INK, (I) 12–14 | Interlude program in | not equal to zero, JNE, | | Input keys, INK, (SR) 11-31 | CMDNC0 6-5 | (R) 11-46 | | Input parameters 18-4 | Interlude programs 6–2 | Jump to subroutine, JSR, (I) 12-20 | | Input to A, INA, (SR) 11–30 | Interrupt notify | Jump, JMP, (I) 12-20 | | Input/output formats (PSD and VPSD only) 18-4 | INBC, (I) 12–20<br>INBC, (V) 11–49 | Jump, JMP, (SRV) 11-46 | | Input/output, I/O (I) 12-14 | INBC, (V) 11-49 | K | | Input/output, I/O (V) 11-29 | INBN, (I) 12–20 | Key manipulation, KEYS (I) 12-14 | | Installation in the command | INEC, (I) 12-20 | Key manipulation, KEYS | | UFD 6-2<br>Instruction | INEC, (V) 11–49 | (V) 11-31<br>Keys (SR) 9-12 | | description conventions 2–1 | INEN, (I) 12–20<br>INEN, (V) 11–49 | Keys (VI) 9-12 | | format (SRV), memory | Interrupt return | KEYS, key manipulation (I) 12-14 | | reference, PMA 14-5 | IRTC, (I) 12–14 | KEYS, key manipulation | | format, memory | IRTN, (I) 12-14 | (V) 11–31 | | reference 10–2<br>format, mnemonic | INTGY (I) 12–14<br>INTGY (V) 11–28 | L | | definitions 2-3 | INTH(I) 12-8 | L, load fullword, (I) 12-18 | | formats 9-14 | INTL (V) 11-22 | L-bit 9-14 | | formats, I-mode 9-16 | Invalidate STLB entry, ITLB, | Label, PMA 14–4 | | formats, PMA 14-6<br>function group definitions 2-2 | (I) 12–17<br>Invalidate STLB entry, ITLB, | Labels 15-8 | | range, relative 10–3 | (V) 11–35 | Language structure, PMA 14-1<br>LB% assembler notation 15-8 | | range, sectored 10-3 | IP pseudo-operation 16-7 | LC, listing control pseudo- | | summary and description | IPVT pseudo-operation 16-16 | operations 16–1 | | conventions 2-2 | IR1 (I) • 12–12 | LCEG (V) 11-33 | | summary chart 13-1<br>INT (V) 11-21 | IR2 (I) 12-12<br>IRB (I) 12-18 | LCEQ (I) 12–16 | | INT (V) 11-21<br>INT (I) 12-8 | IRH (I) 12–18 | LCGE (V) 11–33<br>LCGE (I) 12–16 | | INT (I) 12-9 | IRS (SRV) 11-53 | LCGT (I) 12-16 | | INT (V) 11-22 | IRTC (I) 12-14 | LCLE (V) 11-33 | | INTA (V) 11-21 | IRTN (I) 12-14<br>IRY (SRV) 11-53 | LCLE (I) 12-16 | | Integer arithmetic, INT (I) 12-9 Integer arithmetic, INT (V) 11-22 | IRX (SRV) 11–53<br>ITLB (I) 12–17 | LCLT (V) 11-33<br>LCLT (I) 12-16 | | Integer constants 15–1 | ITLB (V) 11–35 | LCNE (V) 11-33 | | Integer value single | T | LCNE (I) 12–16 | | precision 15-5 | J | LDA (SRV) 11-40 | | Integers, absolute 17-2 | JDX (R) 11-45 | LDAR (I) 12-18 | | LDC (I) 12-4 | LLGE (V) 11-33 | order of (R-mode) 4-2 | |-------------------------------------------------------------------|----------------------------------------|----------------------------------------| | LDC (V) 11-5 | LLGT (V) 11-33 | order of (SEG) 5-3 | | LDL (V) 11-40 | LLL (SRV) 11-51 | R-mode programs 4-1 | | LDLR (V) 11-41 | LLLE (V) 11-33 | | | LDX (SRV) 11-41 | LLLT (V) 11-33 | SEG mode programs 5-2 | | LDY (V) 11-41 | LLNE (V) 11–33 | Local address definition pseudo- | | Leave machine check mode, | LLR (SRV) 11–52 | operation, DAC 16-7 | | LMCM, (I) 12–14 | LLS (SR) 11–52<br>LLS (SR) 11–52 | Local labels within macros 17-2 | | Leave machine check mode, | LLS (V) 11–52 | Location pointer 18–6 | | LMCM, (SRV) 11-28 | LLT (V) 11–32<br>LLT (V) 11–33 | Logic | | Leave paging mode and jump | LLT (I) 12–16 | set A false, LF, (SRV) 11-34 | | (Prime 300), LPMJ, | LMCM (I) 12–14 | set A true, LT, (SRV) 11-34 | | (SR) 11–36 | LMCM (SRV) 11–28 | set false, LF, (I) 12-17 | | LEQ (V) 11-33 | LNE (V) 11-33 | set true, LT, (I) 12–17<br>Logical | | LEQ (I) 12-16 | LNE (I) 12–16 | operations (I) 12–15 | | LF (I) 12–17 | LO loader control pseudo- | operations (1) 12-13<br>operators 15-8 | | LFEQ (I) 12–16 | operations 16-1 | | | LFGE (I) 12-16 | LOAD, R-mode linking loader 4-1 | t t 1 t mome its | | LFGT (I) 12-16 | LOAD | test and set, LTSTS, (V) 11–33<br>Long | | LFLE (I) 12-16 | addressed register, LDAR, | left logical, LLL, (SRV) 11-51 | | LFLI (Ì) 12–6 | (I) 12–18 | left rotate, LLR, (SRV) 11-52 | | LFLI (V) 11–15 | character, LDC, (I) 12-4 | left shift, LLS, (SR) 11-52 | | LFLT (I) 12–16 | character, LDC, (V) 11-5 | left shift, LLS, (V) 11-52 | | LFNE (Í) 12–16 | command summary, R- | reach memory reference | | LGE (V) 11-33 | mode 4-8 | instruction formats 10-6 | | LGE (I) 12–16 | field address register EAFA, | right logical, LRL, (SRV) 11-5 | | LGT (V) 11-33 | (I) 12-6 | right rotate, LRR, (SRV) 11-5 | | LGT (I) 12-16 | field length register immediate, | right shift, LRS, (SR) 11-52 | | LH (I) 12-18 | LFLI, (I) 12-6 | right shift, LRS, (V) 11-53 | | LHEQ (I) 12-16 | field length register immediate, | LPID (I) 12-17 | | LHGE (I) 12-16 | LFLI, (V) 11–15 | LPID (V) 11–36 | | LHGT (I) 12-16 | fullword, L, (I) 12-18 | LPMJ (SR) 11–36 | | LHL1 (I) 12–18 | halfword left shifted by 1, | LPMX (SR) 11-36 | | LHL2 (I) 12-19 | LHL1, (I) 12-18 | LPSW (I) 12-17 | | LHLE (I) 12-16 | halfword shifted by 2, LHL2, | LPSW (V) 11-36 | | LHLT (I) 12-16 | (I) 12–19 | LRL (SRV) 11-52 | | LHNE (I) 12-16 | halfword, LH, (I) 12-18 | LRR (SRV) 11-52 | | LIB UFD library, use with | I/O TLB, LIOT, (V) 11-35 | LRS (SR) 11-52 | | SEG 5–3 | L from addressed register, | LRS (V) 11-53 | | Library | LDRL, (V) 11–41 | LSMD pseudo-operation 16-11 | | subroutines, loading 4–3, 5–3 | long, LDL, (V) 11-40 | LSTM 17-6 | | files sort 8–1 | map entry (R-mode), | LSTM pseudo-operation 16-11 | | memory sort 8-1 | *CMLOW 4–3 | LSTMD 17-6 | | UII 4-4 | map entry (R-mode), | LT, literal pseudo- | | Line format, PMA 14-3 | *HIGH 4–3 | operations 16–1 | | Line terminator 18-6 | map entry (R-mode), | LT, (SRV) 11-34 | | Lines, PMA 14-1 | *LOW 4-3 | LT (I) 12–17 | | Link frame description in load | map entry (R-mode), | LTSTS (I) 12–16 | | map 5-6 | *PBRK_4-3 | LTSTS (V) 11-33 | | LINK pseudo-operation 16-5 | map entry (R-mode), | LWCS (I) 12–17 | | Linkage area, PMA 14-9 | *START 4-3 | LWCS (V) 11-37 | | LIOT (V) 11-35 | maps 4-3 | M | | LIOT (I) 12-17 | maps in SEG 5-3 | M | | LIR pseudo-operation 16-15 | procedures, basic 4-2 | M (I) 12-12 | | List pseudo-operation 16–11<br>Listing control pseudo-operations, | process ID, LPID, (I) 12-17 | MAC pseudo-operation 16-16, | | LC 16-1 | process ID, LPID, (V) 11-36 | 17-2 | | Listing | program status word, LPSW, | Machine control, MCTL, (I) 12-17 | | files 3–1 | (I) 12–17 | Machine control, MCTL, | | format 3-2 | program status word, LPSW, | (V) 11-34 | | page headers 3-1 | (V) 11-36 | Macro | | user generated messages | shift count into A, SCA, | call number 17-2 | | in 3-1 | (SR) 11-27 | calls 15–11, 17–1, 17–2 | | Literal pool 15–10 | state 4-3 | definition pseudo-operations, | | Literal pseudo-operations | subprocessor commands, | MD 16-1 | | LT 16-1 | SEG 5–10<br>the A register, LDA, (SRV) | definitions 15–11, 17–1, 17–2, | | Literals 15–1, 15–10, 18–5 | | 17-4, 17-5, 17-6 | | Literals, PMA 14-9 | error messages 4–1<br>functions 4–4 | facility 17-1 | | LLE (V) 11–33 | Loading | listing 17–6<br>nesting 17–5 | | LLE (I) 12-16 | library subroutines 4–3, 5–3 | self documentation of 17–3 | | LLEQ (V) 11–33 | on page boundaries 4-6 | Man files using 5-3 | | MATHLB, system library 8-1 | Messages, assembler 3-2 | NFYE, (I) 12-20 | |---------------------------------|-------------------------------------|-----------------------------------------| | | | NFYE, (V) 11-49 | | Matrix routines 8–1 | MH (I) 12–12 | | | MCTL (I) 12-17 | MIA (V) 11-37 | NRM (SR) 11-25 | | | MIB (V) 11-37 | Numeric | | MCTL (V) 11-34 | | | | MD, macro definition pseudo- | Microcode indirect A, MIA, | constants 15–1, 15–2 | | operations 16-1 | (V) 11-37 | edit, XEC, (I) 12–5 | | * | | • · · · · · · · · · · · · · · · · · · · | | MDEI (V) 11–28 | Microcode indirect A, MIB, | edit, XED, (V) 11–13 | | MDEI (I) 12-14 | (V) 11-37 | | | | | 0 | | MDII (V) 11–28 | MO, memory overflow errors 7-3 | _ | | MDII (I)12-14 | Modals 9-14 | O(I) 12-15 | | | Mode 18-4 | Object code, loader use of 4-5 | | MDIW (I) 12–14 | | | | MDIW (V) 11-28 | Mode usage, general data | Object file (SEG) | | | structures 2-4 | reorganization 5-8 | | MDRS (I) 12–14 | | | | MDRS (V) 11–28 | Mode, access 18-6 | Object files 3-1 | | | Mode, resultant 15-9 | Object files in SEG 5–8 | | MDWC (I) 12-14 | | | | MDWC (V) 11-28 | Modify subprocessor | OCP (SR) 11-30 | | Memory addressing | commands 5–13 | OCT pseudo-operation 16–11 | | | | Octal 18-5 | | address truncation 10–1 | Move | _ | | indexing 10-1 | character field, ZMV, (I) 12-4 | Octal constants 15-2 | | | character field, ZMV, (V) 11-6 | OH (I) 12-15 | | indirection 10–1 | Character Held, Ziviv, (v) | 011 (1) 12 10 | | parameters 10-1 | data, MOVE, (I) 12–17 | One word memory reference, | | | data, MOVE, (V) 11-39 | indirect word 9–3 | | Memory diagnostic | | | | enable interleave, MDEI, | equal length fields, ZMVD, | Operand field, PMA 14–5 | | (V) 11-28 | (I) 12-4 | Operand, PMA 14-4 | | | | Operation field, PMA 14-5 | | enable interleave, MDEI, | equal length fields, ZMVD, | | | (I) 12–14 | (V) 11-7 | Operation, PMA 14-4 | | | Move (I) 12–17 | Operations 15-8 | | inhipit interleave, MDII, | | | | (V) 11-28 | Move (V) 11-39 | Operator | | inhibit interleave, MDII, (I) | MPL (V) 11-25 | addition 15–9 | | | | | | (I) 12–14 | MPY (V) 11–25 | priority 15–9 | | read syndrome bits, MDRS, | MRFR, memory reference floating | subtraction 15–9 | | | | Operators 15-8, 15-9 | | (I) 12–14 | register 9-17 | | | read syndrome bits. MDRS, | MRGR, memory reference general | arithmetic 15–8 | | | register 9-17 | logical 15–8 | | (V) 11–28 | | <u>.</u> | | write control register, MDWC, | MRNR, memory reference non | relational 15–9 | | (V) 11-28 | register 9–17 | shift 15–8, 15–9 | | | MCORTE auston library 8-1 | Optimizing program performance, | | write interleaved, MDIW, | MSORTS, system library 8-1 | | | (I) 12-14 | Multiply fullword, M, (I) 12-12 | SEG 5-7 | | | Multiply halfword, MH, (I) 12–12 | Optimizing program size, | | write interleaved, MDIW, | Multiply half word, with, (1) 12 12 | | | (V) 11-28 | Multiply long, MPL, (V) 11-25 | SEG 5-7 | | | Multiply, MPY, (V) 11-25 | Options, PMA command line 3-1 | | Memory organization 10-1 | Multiply, Mil 1, (V) 11 =0 | | | Memory overflow errors | | OR fullword, O, (I) 12-15 | | (MO) 7-3 | N | OR halfword, OH, (I) 12–15 | | | | ORA (V) 11-33 | | Memory reference 9-17 | N (I) 12-15 | OKA (V) 11-00 | | concepts (SRV) 10-1 | N64R pseudo-operation 16-15 | ORG pseudo-operation 16-6 | | | Negative numbers 15-5 | Organization of memory 10–1 | | floating register, MRFR 9–17 | Negative numbers 10 0 | | | general register, MRGR 9–17 | Negative scaling 15-4 | OTA (SR) 11-30 | | instruction formats 9-16, 10-1, | Nested calls 17-5 | OTK (I) 12–14 | | | | | | 10-2 | Nesting macros 17-5 | OTK (SR) 11-31 | | instruction formats (SRV), | NFE (I) 12–20 | Out from A, OTA, (SR) 11-30 | | | NFYB (I) 12-20 | Output control pulse, OCP, | | PMA 14–5 | | | | instruction formats, base | NFYB (V) 11-49 | (SR) 11-30 | | register relative 10-1 | NFYE (V) 11-49 | Output keys, OTK, (I) 12-14 | | | | Output keys, OTK, (SR) 11-31 | | instruction formats, base | NH (I) 12–15 | Output keys, OTK, (OK) 11-01 | | registers 10–1 | NLSM pseudo-operation 16–12, | Output values 18-4 | | | | • | | instruction formats, | 17-6 | P | | basic 10-1, 10-4 | NLST pseudo-operation 16-12 | - | | instruction formats, long | No operation, NOP, (I) 12-17 | Page headers listing 3-1 | | | NO operation, 1102, (2) 11 27 | Parameter passing (SR) 8-1 | | reach 10-1 | No operation, NOP, (SRV) 11-37 | | | instruction formats, procedure | Non-register generic instruction | Parameter passing (VI) 8–1 | | | | Pathname, use of in SEG 5-1, 5-8 | | relative 10–1 | formats 9–17 | | | instruction formats, sector | NOP (I) 12-17 | Pathnames, use of 4-5 | | _ | NOP (SRV) 11-37, 11-55 | PB% assembler notation 15-8 | | relative 10-1 | | | | instruction formats, stack | Normalization 11-16, 12-6 | PCL stack frame header 9-4 | | postincrement 10-1 | Normalize, NRM, (SR) 11-25 | PCL (I) 12-20 | | postmorement 10-1 | Normalized fraction 15-5 | PCL (V) 11-47 | | instruction formats, stack | | | | predecrement 10-1 | Not 64R pseudo-operation, | PCTLJ (I) 12–19 | | | N64R 16-15 | PCTLÍ (V) 11-43 | | instruction formats, stack | | | | relative 10-1 | Notify, | PCVH pseudo-operation 16-12 | | non register, MRNR 9 17 | NFYB, (I) 12-20 | Percent sign, PMA 14–5 | | | NFYB, (V) 11–49 | PFTNLB library, use with | | two word 10–8 | MEID, (V) 11-49 | II IIVDD HDIAIY, ase with | | SEG 5-2 | (SR) 11-26 | BSZ 16-20 | |------------------------------------|--------------------------------------------|--------------------------| | PFTNLB, system library 8-1 | for integer divide, PIDA, | C64R 16-5 | | PID (I) 12–12 | (V) 11-26 | CALL 16-18 | | PID (SR) 11-26 | for integer divide-long, PIDL, | CENT 16-14 | | PIDA (V) 11–26 | (V) 11-26 | COMM 16-20 | | PIDH (I) 12–12<br>PIDL (V) 11–26 | half register after multiply, | D16S 16-14 | | PIM (I) 12–13 | PIMH, (I) 12-13 | D32I 16-14 | | PIM (SR) 11–26 | half register for integer divide, | D32R 16-14 | | PIMA (V) 11–26 | PIDH, (I) 12–12<br>Pound sign(#) assembler | D32S 16–14<br>D64R 16–14 | | PIMH (I) 12–13 | notation 14–5, 15–11 | D64V 16-14 | | PIML (V) 11-26 | Powers of 10 (E) 15–4 | DAC 16-7 | | PL, program linking pseudo- | PRCEX, process exchange (I) 12-20 | DATA 16-10 | | operations 16–1 | PRCEX, process exchange (V) 11-49 | DDM 16-14 | | PM 18-3 | (restricted) 11-49 | DEC 16-10 | | PM command 7-1 | Precision 15-4 | DFTB 16-8 | | PMA concepts and facilities | double 15–1 | DFVT 16-8 | | asterisk (current | single 15–1 | DUII 16-15 | | location) 14-6 | Prime conventions 2-1 | DYNM 16-21 | | asterisk, double (initial | PRIMOS severe errors, | DYNT 16–19 | | zero) 14-6 | debugging 7–2 | ECB 16-19 | | asterisk, triple (dummy | PROC pseudo-operation 16-6 | EJCT 16-11 | | instruction) 14-5 | Procedure | ELM 16-15 | | base registers 14–6<br>code 14–9 | call, PCL, (I) 12–20 | ELSE 16-8 | | command line options 3-1 | call, PCL, (V) 11-47 | END 16-5 | | comments 14-4 | frame description in load<br>map 5–6 | ENDC 16-9 | | constants 14-4 | relative memory reference | ENDM 16–16<br>ENT 16–20 | | elements 14-4 | instruction formats 10-4 | EQU 16-21 | | error messages 7-1, C-1 | return, PRTN, (I) 12-20 | EVEN 16-5 | | examples 14-9 | return, PRTN, (V) 11-48 | EXT 16-19 | | expressions 14-4 | structure load map | FAIL 16-9 | | file types 3–1 | description 5-6 | FIN 16-12 | | formats 14–7 | Procedures with no names, | GO 16-9 | | I-mode 14–6 | identification in load | HEX 16-11 | | indexing 14–5 | maps 5-6 | IF 16-9 | | indirection 14-5 | Process exchange, PRCEX, (V) | IFTF 16-9 | | instruction formats 14-6 | 11-49 | IFTT 16-9 | | label 14-4 | Process exchange, PRCEX, | IFVF 16-9 | | language structure 14-1 | (I) 12–20 | IFVT 16-9 | | line format 14–3<br>lines 14–1 | Processor characteristics 9-8 | IFX 16-9 | | linkage area 14–9 | Program control and jump, PCTLJ, | IP 16-7 | | literals 14-9 | (I) 12–19 Program control and jump, PCTLJ, | IPVT 16–16<br>Link 16–5 | | memory reference instruction | (V) 11-43 | LINK 10-5<br>LIR 16-15 | | format (SRV) 14-5 | Program linking pseudo- | LIK 16-15<br>LIST 16-11 | | operand 14-4 | operations, PL 16-1 | LSMD 16-11 | | operand field 14-5 | Program memory images saved by | LSTM 16-11 | | operation field 14–5 | load 6-2 | MAC 16-16 | | percent sign 14–5 | PRTN, procedure return, | N64R 16-15 | | pound sign (#) 14-5 | (I) 12-20 | NLSM 16-12 | | stack 14-6 | PRTN, procedure return, | NLST 16-12 | | stack 14-8 | (V) 11–48 | OCT 16-11 | | statements 14-1, 14-2 | PSD (Prime symbolic | ORG 16-6 | | symbolic addresses 14-5 | debugger) 18-1, | PCVH 16-12 | | symbols 14–4<br>syntax 14–4 | 18-3,18-4,20-1 | PROC 16-6 | | types 14-1 | command summary 20-1 | REL 16-6 | | PMA V or I mode code, how to | terminators 20–1 | RLIT 16-12 | | write 14-8 | using 18–3<br>PSD and VPSD input/output | SAY 16-16 | | Position | formats 18-4 | SCT 16-17<br>SCTL 16-17 | | after multiply, PIM, (I) 12–13 | PSD, VPSD terminators 21-1 | SDM 16-15 | | following integer multiply, PIM, | PSD30 18-3 | SEG, 64V 16-6 | | (SR) 11-26 | Pseudo-operation summary 16-2 | SEGR, 32I 16-6 | | following integer multiply, | Pseudo-operations | SET 16-21 | | PIMA, (V) 11–26 | ABS 16-5 | SETB 16-15 | | following integer multiply-long, | AP 16-7 | SUBR 16-20 | | PIML, (V) 11–26 | BACK 16-8 | VFD 16-11 | | for integer divide, PID, (I) 12-12 | BCI 16-10 | XAC 16-7 | | (I) 12-12 | BES 16-20 | XSET 16-21 | | for integer divide, PID, | BSS 16-20 | PTLB (I) 12–17 | | DELD (17) 44 97 | ESIM 11-30 | SGL 11-27 | |------------------------------|------------|----------------------------------| | PTLB (V) 11-37 | | SGT 11-54 | | Purge TLB, PTLB, (I) 12-17 | EVIM 11-30 | | | Purge TLB, PTLB, (V) 11-37 | EVMJ 11-35 | SKP 11-54, 11-55 | | Purpose of I-mode 9-16 | EVMX 11-35 | SKS 11-31 | | 1 dipost of a second | EXB 11-43 | SLE 11-54. | | 0 | FAD 11-18 | SLN 11-55 | | Q | | SLZ 11-55 | | Question mark (?) 18-4 | FCM 11-19 | | | Queue control block (VI) 9-7 | FCS 11-19 | SMCR 11-29 | | Queue management, QUEUE | FCST 11-20 | SMCS 11-29 | | • | FDV 11-19 | SMI 11-55 | | (I) 12-20 | FLD 11-19 | SNR 11-54 | | Queue management, QUEUE | | SNS 11-54 | | (V) 11-49 | FLOT 11-19 | | | QUEUÉ, queue management | FMP 11-20 | SNZ 11-55 | | (I) 12-20 | FRN 11-20 | SPL 11-55 | | QUEUE, queue management | FSB 11-20 | SR2 11-55 | | | FSLE 11-20 | SR3 11-55 | | (V) 11-49 | | SR4 11-55 | | | FSMI 11-21 | | | R | FSNZ 11-21 | SRC 11-55 | | R registers 9–8 | FSPL 11-21 | SRL 11-55 | | R-mode instructions | FST 11-21 | SS1 11–55 | | | FSZE 11-21 | SS2 11-55 | | A2A 11–22 | | SS3 11-55 | | ACA 11-22 | HLT 11-35 | | | ADD 11-22 | IAB 11-40 | SS4 11-55 | | ALA 11-22 | ICL 11-40 | SSC 11-55 | | ALL 11-51 | ICR 11-40 | SSM 11-27 | | | IMA 11-40 | SSP 11-27 | | ALR 11-51 | | SSR 11-55 | | ALS 11-51 | INA 11-30 | | | ANA 11-32 | INH 11–30 | SSS 11-55 | | ARL 11-51 | INK 11-31 | STA 11-41 | | | IRS 11-53 | STR 11-48 | | ARR 11-51 | IRX 11-53 | STX 11-42 | | ARS 11-51 | | | | CAJ 11-29 | JDX 11-45 | SUB 11-27 | | CAL 11-7 | JED 11-45 | SVC 11-39 | | CAR 11-7 | IGE 11-45 | SZE 11-55 | | | JGT 11-45 | TCA 11-28 | | CAS 11-23 | IIX 11-46 | VIRY 11-29 | | CAZ 11-23 | , | | | CEA 11-44 | JLE 11-46 | WCS 11-39 | | CHS 11-23 | JLT 11-46 | XCA 11-43 | | CMA 11-32 | JMP 11-46 | XEC 11-49 | | | JNE 11-46 | R-mode programs, Loading 4-1 | | CRA 11-7 | | RBQ (V) 11-50 | | CRB 11-8 | JST 11-46 | | | CREP 11-44 | JSX 11-47 | RCB (I) 12–15 | | CRL 11-8 | LDA 11-40 | RCB (SRV) 11-31 | | CSA 11-24 | LDX 11-41 | Recursive entry, R-mode 11–44 | | DAD 11-24 | LF 11-34 | Register description VI-mode 9-9 | | | LLL 11-51 | Register generic 9-17 | | DBL 11-24 | LLR 11-52 | Register, index 18-4 | | DFAD 11–17 | | Deleter DCAV (I) 12 17 | | DFCM 11-17 | LLS 11-52 | Register save, RSAV, (I) 12-17 | | DFCS 11-17 | LMCM 11-28 | Register to register instruction | | DFDV 11-17 | LPMI 11-36 | formats 9–17 | | DFLD 11-18 | LPMX 11-36 | Registers (R) 9-8 | | | LRL 11-52 | Registers (S) 9-8 | | DFMP 11-18 | LRR 11-52 | Registers (VI) 9-9 | | DFSB 11-18 | | Desisters been DMA 14.6 | | DFST 11-18 | LRS 11-52 | Registers, base, PMA 14-6 | | DIV 11-24 | LT 11-34 | REL pseudo-operation 16-6 | | DLD 11-39 | NOP 11-37 | Relational operators 15-9 | | | NOP 11-55 | Relative addresses 18-4 | | DRX 11-53 | NRM 11-25 | Relative base 10-6 | | DSB 11-24 | | | | E16S 11-1 | OCP 11-30 | Relative reach 10-1 | | E32I 11-1 | OTA 11-30 | Relocatable mode 18-4 | | E32R 11-1 | OTK 11-31 | Relocation constant 18–4 | | | PID 11-26 | Remove | | E32S 11-1 | PIM 11-26 | from bottom of queue, RBC, | | E64R 11-1 | | (I) 12–21 | | E64V 11-1 | RCB 11-31 | (1) 12-21<br>for a bottom of DDC | | EAA 11-44 | RMC 11-28 | from bottom of queue, RBC, | | EMCM 111-28 | SLA 11-26 | (V) 11-50 | | ENB 11-39 | S2A 11-27 | from top of queue, RTQ, | | END 11-39<br>EBTR 11-45 | SAR 11-53 | (I) 12-21 | | | SAS 11-53 | from top of queue, RTQ, | | EPMJ 11-34 | | (V) 11-50 | | ERA 11-32 | SCA 11-27 | | | ERMX 11-35 | SCB 11-31 | Replacing modules in a SEG | | | | | | runfile 5-7 | Segmented programs, loading 5-1 | (SRV) 11-55 | |---------------------------------------------------------------------|----------------------------------------------------------------------|-------------------------------------------------------------| | Reset C-bit (clear), RCB, (I) 12-15 | Segmented runfiles 5-1, 5-7, 6-2, | condition lsb nonzero (a(16)=1) | | Reset C-bit, RCB, (SRV) 11-31<br>Restore registers, RRST, (I) 12-17 | 6-3 | SLN, (SRV) 11–55 | | Restore registers, RRST, | SEGR pseudo-operation 16–6<br>Selecting the address mode 4–5 | condition lsb zero (a(16)=0),<br>SLZ, (SRV) 11–55 | | (V) 11–38 | Self documentation of | condition sense switch 1 reset, | | Resultant mode 15-9 | macros 17-3 | SRL, (SRV) 11-55 | | Return from R-mode recursive | Semicolon, assembler | condition sense switch 1 set, | | procedure, RTN, (SR) 11-48 | notation 15-10 | SS1, (SRV) 11-55 | | RLIT pseudo-operation 15-10,<br>16-12 | Set C-bit, SCB, (I) 12–15<br>Set C-bit, SCB, (SRV) 11–31 | condition sense switch 2 reset, | | RMC (I) 12-14 | Set sign minus, SSM, (I) 12–13 | SR2, (SRV) 11–55<br>condition sense switch 2 set, | | RMC (SRV) 11-28 | Set sign minus, SSM, (SRV) 11-27 | SS2, (SRV) 11-55 | | ROT (I) 12-21 | Set sign plus, SSP, (I) 12–13 | condition sense switch 3 reset, | | Rotate, ROT, (I) 12–21 | Set sign plus, SSP, (SRV) 11-27 | SR3, (SRV) 11-55 | | Round up, FRN, (RV) 11–20<br>RRST (I) 12–17 | SGL (SR) 11-27<br>SGT (SRV) 11-54 | condition sense switch 3 set, | | RRST (V) 11–38 | SH (I) 12-13 | SS3, (SRV) 11–55<br>condition sense switch 4 reset, | | RSAV (I) 12-17 | SHA (I) 12–22 | SR4, (SRV) 11-55 | | RSAV (V) 11-38 | Shift 9-14 | condition sense switch 4 set, | | RTN (SR) 11-48 | arithmetic, SHA, (I) 12–22 | SS4, (SRV) 11-55 | | RTQ (I) 12-21 | data 12–21 | condition set C, SSC, | | RTQ (V) 11-50<br>Run-time error messages 6-5 | group 11-50 | (SRV) 11-55 | | Runfiles 4-5 | half register left 1, SHL1,<br>(I) 12–22 | satisfied, SKS, (SR) 11–31<br>A bit reset, SAR, (SRV) 11–53 | | saved by SEG's loader 6-3 | half register left 2, SHL, | A bit set, SAS, (SRV) 11–53 | | segmented 5–7 | (I) 12-23 | machine check reset, SMCR, | | segmented, advantages of 5-1 | half register right 1, SHR1, | (SRV) 11-29 | | RVEC parameters 7-1<br>RVI, single precision, floating | (I) 12-23 | machine check set, SMCS, | | point register 9-10 | half register right 2, SHR2,<br>(I) 12–23 | (SRV) 11–29<br>sense switch reset, SNR, | | - | logical, SHL, (I) 12–22 | (SRV) 11–54 | | S | operators 15-8 | sense switch set, SNS, | | S registers 9–8 | operators 15-9 | (SRV) 11-54 | | S(I) 12-13<br>S2A (SDV) 11 27 | register left 1, SL1, (I) 12-22 | Skip unconditionally, SKP, | | S2A (SRV) 11–27<br>SA, storage allocation pseudo- | register left 2, SL2, (I) 12-22 | (SRV) 11-55 | | operations 16-1 | register right 1, SRL, (I) 12–22<br>register right 2, SR2, (I) 12–22 | SKIP, skip conditional (V) 11–53<br>SKP (SRV) 11–54 | | Sample terminal session 2-5 | SHL (I) 12–23 | SKS (SR) 11–31 | | SAR (SRV) 11-53 | SHL 12-22 | SL1 (I) 12-22 | | SAS (SRV) 11-53 | SHL1 (I) 12–22 | SL2 (I) 12-22 | | Save registers, RSAV, (V) 11–38<br>SAY pseudo operation, usage 3–1, | SHR1 (I) 12-23 | SLA (SRV) 11-26 | | 16-16 | SHR2 (I) 12–23<br>Sign bit 15–4 | SLE (SRV) 11–54<br>SLN (SRV) 11–55 | | SB% (seg modes) assembler | Sign conventions 15–9 | SLZ (SRV) 11–55 | | notation 15–8 | Single precision 15-1 | SMCR (SRV) 11-29 | | SBL (V) 11-27 | Single precision floating | SMCS (SRV) 11-29 | | SCA (SR) 11–27<br>Scale differential 9–2 | point 15-5 | SMI (SRV) 11–55 | | Scaling, binary 15-5 | Single precision integer value 15–5 | SNR (SRV) 11–54<br>SNS (SRV) 11–54 | | Scaling, negative 15–4 | Skip conditional, SKIP (V) 11-53 | SNZ (SRV) 11-55 | | SCB (I) 12–15 | Skip group, SKP, (SRV) 11-54 | Sort library 8-1 | | SCB (SRV) 11–31 | Skip if | Source files 3-1 | | SCT pseudo-operation 16–17<br>SCTL pseudo-operation 16–17 | A greater than zero, SGT, | Space conventions 15-9 | | SD, symbol definition pseudo- | (SRV) 11–54<br>less than or equal to zero, SLE, | Special case selection address | | operations 16-1 | (SRV) 11–54 | formation 9–18<br>SPL (SRV) 11–55 | | SDM pseudo-operation 16–15 | condition A minus $(a(1)=1)$ , | SR address truncation 10-2 | | Sector relative memory reference | SMI, (SRV) 11–55 | SR keys 9-12 | | instruction formats 10–4<br>Sectors 10–1 | condition A nonzero, SNZ, | SR subroutine call | | SEG 18-3 | (SRV) 11-55 | conventions 8-2 | | filename 1/1 18-3 | condition A plus (a(1)=0), SPL,<br>(SRV) 11-55 | SR1 (I) 12-22<br>SR2 (I) 12-22 | | load map components 5-4 | condition A zero, SZE, | SR2 (1) 12-22<br>SR2 (SRV) 11-55 | | loader <sup>*</sup> 5–7 | (SRV) 11-55 | SR3 (SRV) 11-55 | | VPSD 18-3 | condition all sense switches 1-4 | SR4 (SRV) 11-55 | | SEG level commands 5-9 | set, SSS, (SRV) 11-55 | SRC 11-55 | | SEG pseudo-operation 16–6<br>Segment directory subfiles 5–7 | condition any of sense switches | SRL (SRV) 11-55 | | Segment unectory submes 5-7 Segment usage by SEG 5-7 | 1–4 reset, SSR,<br>(SRV) 11–55 | SRTLIB, system library 8–1<br>SS1 (SRV) 11–55 | | Segmentation 10-1 | condition clear C, SRC, | SS2 (SRV) 11-55 | | SS3 (SRV) 11-55 | (V) 11-42 | Terms 15-5 | |------------------------------------|-----------------------------------|-----------------------------------| | SS4 (SRV) 11-55 | long, STL, (V) 11-41 | Test | | | process model number, STPM, | A register equal to zero and set | | SSC (SRV) 11-55 | • | A, LEG, (V) 11–33 | | SSM (I) 12–13 | (I) 12–17 | ` ' . | | SSM (SRV) 11–27 | processor model number, | A register greater than or equal | | SSP (I) 12–13 | STPM, (V) 11–38 | to zero and set A, LGE, | | SSP (SRV) 11-27 | the A register, STA, | (V) 11–33 | | SSR (SRV) 11–55 | (SRV) 11-41 | A register greater than zero and | | | X register, STX, (SRV) 11-42 | set A, LGE, (V) 11-33 | | SSS (SRV) 11-55 | | A register greater than zero and | | ST (I) 12-19 | Y, STY, (V) 11-42 | | | ST.SIZE, SEG load map entry 5–6 | STPM (I) 12–17 | set R, LGT, (I) 12-16 | | STA (SRV) 11-41 | STPM (V) 11–38 | A register less than or equal to | | STAC (V) 11-41 | STX (SRV) 11–42 | zero and set A, LLE, | | Stack | STY (V) 11-42 | (V) 11-33 | | assignment (SEG) 5-8 | SUB (SŔV) 11-27 | A register less than zero and se | | | SUBR pseudo-operation 16-20 | A, LLT, (V) 11-33 | | extend, STEX, (I) 12-10 | • • | A register not equal to zero and | | extend, STEX, (V) 11-48 | Subroutine call conventions, | | | frame description in load | (SR) 8-2 | set A, LNE, (V) 11–33 | | map 5-6 | Subroutine call conventions, | condition code equal to zero | | frame header CALF 9–5 | (VI) 8–3 | and set A, LCEQ, | | frame header PCL 9-4 | Subroutine calling 8-1 | (V) 11-33 | | | Subroutines, loading library 4–3, | conditión code equal to zero | | overflow, SEG load map | 5–3 | and set R, LCEQ, | | information 5-3 | | | | postincrement address | Subtract | (I) 12–16 | | formation 10–6 | fullword, S, (I) 12–13 | condition code greater than or | | predecrement address | halfword, SH, (I) 12–13 | equal to zero and set A, | | formation 10-6 | long, SBL, (V) 11-27 | LCEG, (V) 11-33 | | relative (R-mode) memory | one from A, SLA, (SRV) 11-26 | condition code greater than or | | | | equal to zero and set R, | | reference instruction | two from A, S2A, (SRV) 11–27 | | | formats 10-8 | Subtract, SUB, (SRV) 11-27 | LCGE (I) 12–16 | | segment header 9–4 | Subtraction operator 15–9 | condition code greater than | | Stack, PMA 14-6, 14-8 | Supervisor call, SVC, (I) 12-20 | zero and set A, LCGT, | | Stack, SEG assignment of 5-8 | Supervisor call, SVC, | (V) 11-33 | | | (SRV) 11-39 | condition code greater than | | STAR (I) 12-19 | SVC (I) 12-20 | zero and set R, LCGT, | | START 18-3 | | (I) 12–16 | | Starting a loaded program 6-1 | SVC (SRV) 11-39 | | | Statements, PMA 14-1, 14-2 | Symbol definition pseudo- | condition code less than or | | STC (V) 11-5 | operations, SD 16-1 | equal to zero and set A, | | STC (I) 12-4 | Symbol definitions in load | LCLE, (V) 11–33 | | STCD (I) 12-19 | maps 4-4 | condition code less than or | | | Symbolic addresses, PMA 14-5 | equal to zero and set R, | | STCH (I) 12–19 | Symbolic instruction format 18-5 | LCLE, (I) 12-16 | | STEX (I) 12-20 | | | | STEX (V) 11-48 | Symbols, PMA 14-4 | condition code less than zero | | STFA (I) 12-6 | Syntax, PMA 14-4 | and set A, LCLT, | | STFA (V) 11-15 | System error messages 4–1, C | (V) 11-33 | | STH (I) 12-19 | System errors, SEG's action 5-1 | condition code less than zero | | /_ /_ /_ /_ /_ /_ /_ /_ /_ /_ /_ / | System libraries 8-1 | and set R. LCLT, (I) 12-16 | | STL (V) 11-41 | System programming | condition code not equal to zero | | STLC (V) 11-42 | features 4-6 | and set A, LCNE, | | STLR (V) 11-42 | | | | Storage allocation pseudo- | SZE (SRV) 11–55 | (V) 11-33 | | operations, SA 16–1 | Т | condition code not equal to zero | | Store | 1 | and set R, LCNE, | | A conditionally, STAC, | TAB (V) 11-42 | (I) 12–16 | | (V) 11-41 | TAK (V) 11-31 | floating register equal to zero | | addressed register, STAR, | TAP (Trace And Patch) 18-1 | and set A, LFÉQ, | | | command summary 19–1 | (V) 11-34 | | (I) 12-19 | | floating register equal to zero | | character, STC, (I) 12–4 | terminators 19-1 | | | character, STC, (V) 11-5 | using 18–1 | and set R, LFEQ, (I) 12–16 | | conditional fullword, STCC, | TAX (V) 11-42 | floating register greater than or | | (I) 12–19 | TAY (V) 11-42 | equal to zero and set A, | | conditional fullword, STCH, | TBA (V) 11-43 | LFGE, (V) 11–34 | | | TC (I) 12–13 | floating register greater than or | | (I) 12-19 | TCA (SRV) 11-28 | equal to zero and set R, | | field address register, STFA, | ` , | | | (I) 12-6 | TCH (I) 12-13 | LFGE, (I) 12-16 | | field address register, STFA, | TCL (V) 11-28 | floating register greater than | | (V) 11-15 | Terminating long | zero and set A, LFGT, | | fullword, ST, (I) 12-19 | operations 18-1, 18-3 | (V) 11-34 | | halfword, STH, (I) 12-19 | Terminators 18-4 | floating register greater than | | | Terminators, PSD 20-1 | zero and set R, LFGT, | | L conditionally, STLC, | Terminators, TAP 19-1 | (I) 12–16 | | (V) 11-42 | Terminators, VPSD 21-1 | floating register less than or | | Linto addressed register STLR | reconnanors, VPau - 41-1 | moaning register ress than of | | equal to zero and set A, | TMH (I) 12-14 | BCGE 11-2 | |-----------------------------------------------------------|----------------------------------------------------------|--------------------------| | LFLE, (V) 11-34 | TOP, SEG load map entry 5-6 | BCGT 11-2 | | floating register less than or equal to zero and set R, | Transfer<br>A or B, TAB, (V) 11–42 | BCLE 11-2<br>BCLT 11-2 | | LFLE, (I) 12–16 | A to keys, TAK, (V) 11-42<br>A to keys, TAK, (V) 11-31 | BCNE 11-2 | | floating register less than zero | A to X, TAX, (V) 11-42 | BCR 11-3 | | and set A, LFLT, | A to Y, TAY, (V) 11-42 | BCS 11-3 | | (V) 11-34 | B to A, TBA, (V) 11-43 | BDX 11-4 | | floating register less than zero | field length register to L, TFLL, | BDY 11-4 | | and set R, LFLT, (I) 12-16 | (V) 11-15 | BEQ 11-4 | | floating register not equal to zero and set A. LFNE. | field length to register, TFLR,<br>(I) 12–5 | BFEQ 11-4<br>BFGE 11-4 | | (V) 11–34 | keys to A, TKA, (V) 11-31 | BFGT 11-4 | | floating register not equal to | X to A, TXA, (V) 11-43 | BFLE 11-4 | | zero and set R, LFNE, | Y to A, TYA, (V) 11-43 | BFLT 11-4 | | (I) 12–16 | Translate character field, ZTRN, | BFNE 11-4 | | half register equal to zero and | (V) 11-7 | BGE 11-4 | | set R, LHEQ, (I) 12-16 | Translate character fields, ZTRR, | BGT 11-4<br>BIX 11-4 | | half register greater than or equal to zero and set R, | (I) 12–4<br>Triple asterisk (dummy | BIX 11-4<br>BIY 11-4 | | LHGE, (I) 12–16 | instruction), PMA 14-5 | BLEQ 11-4 | | half register greater than zero | TSTQ (I) 12-21 | BLGE 11-4 | | and set R, LHGT, | TSTQ (V) 11-50 | BLGT 11-4 | | (I) 12-16 | Two word memory reference (V- | BLLE 11-4 | | half register less than or equal | mode) 10–8 | BLLT 11-4 | | to zero and set R, LHLE,<br>(I) 12–16 | Two word memory reference,<br>indirect pointer 9-3 | BLNE 11-4<br>BLE 11-4 | | half register not equal to zero | Two's complement | BLR 11-3 | | and set R, LHNE, | A, TCA, (SRV) 11–28 | BLS 11-3 | | (I) 12-16 | half register, TCH, (I) 12-13 | BLT 11-4 | | L register equal to zero and set | long, TCL, (V) 11–28 | BMEQ 11-3 | | A, LLEQ, (V) 11–33 | register, TC, (I) 12-13 | BMGE 11-3 | | L register greater than or equal to zero and set A, LLGE, | TXA (V) 11–43<br>TYA (V) 11–43 | BMGT 11-3 | | (V) 11–33 | Types, PMA 14-1 | BMLE 11-3<br>BMLT 11-3 | | L register greater than zero and | | BMNE 11-3 | | set A, LLGT, (V) 11–33 | U | BNE 11-4 | | L register less than or equal to | UII | CAI 11-29 | | zero and set A, LLLE, | handling 4-6 | CAL 11-7 | | (V) 11–33<br>L register less than zero and set | library 4-4 | CAR 11-7<br>CAS 11-23 | | A, LLLT, (V) 11–33 | library, loader use of 4-4<br>Unsatisfied references 5-7 | CAS 11-23<br>CAZ 11-23 | | L register not equal to zero and | Unsegmented runfiles, execution | CGT 11-4 | | set A, LLNE, (V) 11–33 | of 6–1 | CLS 11-23 | | L-bit 11-3 | Using the assembler, terminal | CMA 11-32 | | memory fullword, TM, | session example 2-5 | CRA 11-7 | | (I) 12–14<br>memory halfword, TMH, | Using the R-mode loader under<br>PRIMOS 4–1 | CRB 11-8<br>CRE 11-8 | | (I) 12–14 | Using VPSD 18-3 | CRE 11-8<br>CRL 11-8 | | queue, TSTQ, (I) 12-21 | C | CRLE 11-8 | | queue, TSTQ, (V) 11-50 | V | CSA 11-24 | | register equal to zero and set R, | V-mode instructions | CXCS 11-34 | | LEQ, (I) 12-16 | A2A 11-22 | DFAD 11-17 | | register greater than or equal to zero and set R, LGE, | ABQ 11-49<br>ACA 11-22 | DFCM 11-17<br>DFCS 11-17 | | (I) 12–16 | ADD 11–22 | DFDV 11-17 | | register less than or equal to | ADL 11-22 | DFLD 11-18 | | zero and set R, LLE, | ADLL 11-23 | DFLX 11-18 | | (I) 12-16 | ALA 11-22 | DFMP 11-18 | | register less than zero and set R, | ALFA 11-15 | DFSB 11-18 | | LLT, (I) 12–16<br>register not equal to zero and | ALL 11-51<br>ALR 11-51 | DFST 11-18 | | set R, LNE, (I) 12–16 | ALS 11-51 | DIV 11-24<br>DRX 11-53 | | Text conventions 2-1 | ANA 11-32 | DVL 11-25 | | TFLL (V) 11-15 | ANL 11-32 | E16S 11-1 | | TFLR (I) 12-5 | ARGT 11-43 | E32I 11-1 | | Three word memory reference, | ARL 11-51 | E32R 11-1 | | indirect pointer 9–3<br>TKA (V) 11–31 | ARR 11-51<br>ARS 11-51 | E32S 11-1 | | TLFL (V) 11-15 | ATQ 11-49 | E64R 11-1<br>E64V 11-1 | | TM (I) 12-14 | BCEQ 11-2 | EAFA 11-15 | | EAI. 11-44 | LFNE 11-34 | SRC 11-55 | |----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------------------------| | EAL 11-44 EALB 11-45 EAXB 11-45 EIO 11-29 EMCM 11-28 ENB 11-39 ERA 11-32 ERI 11-30 EVIM 11-30 EXB 11-43 FAD 11-18 FCM 11-19 FCS 11-19 FCS 11-19 FCST 11-20 FDBL 11-19 FLTA 11-20 FMP 11-20 FMP 11-20 FMP 11-20 FSB 11-20 FSB 11-21 FSPL 11-21 FSPL 11-21 FSPL 11-21 FSPL 11-21 FST 11-21 FST 11-21 FST 11-21 HLT 11-35 IAB 11-40 ICL 11-40 ICR 11-40 IMA 11-40 INBC 11-49 11-46 IST 11-46 IST 11-46 IST 11-46 IST 11-47 | LFNE 11-34 LGE 11-33 LGT 11-33 LIOT 11-35 LLE 11-33 LLEQ 11-33 LLEQ 11-33 LLEGE 11-33 LLLE 11-33 LLLT 11-33 LLLT 11-33 LLLT 11-33 LLNE 11-33 LLNE 11-33 LLNE 11-33 LLR 11-52 LLS 11-52 LLT 11-33 LMCM 11-28 LNE 11-36 LPSW 11-36 LPSW 11-36 LRL 11-52 LRS 11-52 LRS 11-53 LT 11-34 LWCS 11-37 MDEI 11-28 MDII 11-28 MDII 11-28 MDIW 11-28 MDIW 11-28 MDIW 11-28 MDIW 11-28 MDIW 11-28 MDWC 11-28 MDWC 11-28 MIA 11-37 MIB 11-37 MPL 11-25 NFYB 11-49 NFYE 11-49 NFYE 11-49 NFYE 11-49 NFYE 11-49 NFYE 11-49 NFYE 11-49 NOP 11-55 PCL 11-47 PIDA 11-26 PIML 11-26 PIML 11-26 PIML 11-26 PIML 11-26 PIML 11-26 PIML 11-28 RRST 11-31 RMC 11-28 RRST 11-38 RSAV 11-38 RSAV 11-38 RSAV 11-38 RTQ 11-50 S1A 11-26 S2A 11-53 | SRL 11-55 | | EALB II-45 | LGE 11-33 | 3KL 11-00 | | EAXB 11-45 | LGT 11-33 | SS1 11-55 | | FIO 11 20 | LIOT 11-35 | SS2 11-55 | | EIO 11-29 | HO1 11 00 | CC0 44 FF | | EMGM 11-28 | LLE 11-33 | SS3 11-55 | | ENB 11_39 | LLEO 11-33 | SS4 11-55 | | ED 4 44 00 | II.CE 11 00 | SSC 11-55 | | ERA 11-32 | LLGE 11-33 | 99C 11-99 | | ERL 11-32 | LLGT 11-33 | SSM 11-27 | | ECIM 11 20 | III 11 51 | SSP 11-27 | | ESIM 11-30 | LLL 11-31 | 55F 11-2/ | | EVIM 11-30 | LLLE 11-33 | SSR 11-55 | | EVD 11 40 | IIIT 11 22 | SSS 11-55 | | EAD 11-43 | TTTT 11-00 | 333 11-33 | | FAD 11-18 | LLNE 11-33 | STA 11-41 | | ECM 11 10 | LLD 11-52 | STAC 11-41 | | LCM II-19 | TLO 11-02 | 31AC 11-41 | | FCS 11-19 | LLS 11-52 | STC 11-5 | | FCST 11 20 | LLT 1133 | STEX 11-48 | | TG01 11-20 | L) (C) ( 44 00 | SIEX 11-40 | | FDBL 11-19 | LMCM 11-28 | STFA 11-15 | | FDV 11-19 | LNE 11-33 | STL 11-41 | | ELD 44.40 | I DID 11 26 | 91F 11-41 | | FLD 11-19 | LPID 11-30 | STLC 11-42 | | FLTA 11-20 | LPSW 11-36 | STLR 11-42 | | PITT 44 00 | I DI 11 E9 | 31LK 11-42 | | FLIL 11-20 | LKL 11-52 | STPM 11-38 | | FMP 11-20 | LRR 11-52 | STX 11-42 | | EDN 11 00 | IDC 11 52 | 31A 11-42 | | FRN 11-20 | LIKO 11-00 | STY 11-42 | | FSB 11-20 | LT 11-34 | SUB 11-27 | | ECIE 11 20 | LWCS 11-37 | 30B 11-27 | | FOLE 11-20 | LVGD 11-07 | SVC 11-39 | | FSMI 11-21 | MDEI 11-28 | SZE 11-55 | | ECNI7 11 91 | MDII 11_28 | 0211 11-00 | | 70'NZ 11-Z1 | MDIM 44 00 | TAB 11-42 | | FSPL 11-21 | MD1W 11-28 | TAK 11-31 | | FST 11-21 | MDRS 11-28 | TIAN 11 01 | | FOOTE 44 04 | MDWC 11 20 | TAX 11-42 | | FSZE 11-21 | MDWC 11-26 | TAY 11-42 | | HI.T 11-35 | MIA 11-37 | TBA 11-43 | | TAD 11 40 | MIR 11_37 | 1DA 11-43 | | IAD 11-40 | NIID 11-07 | TCA 11-28 | | ICL 11-40 | MPL 11-25 | TCL 11-28 | | ICP 11_40 | MPY 11-25 | TCL 11-20 | | IGK 11-40 | NEVD 44 40 | TFLL 11-15 | | ILE 11-40 | NFYB 11-49 | TKA 11-31 | | IMA 11-40 | NFYE 11-49 | TK/1 11-01 | | INITIO 11 10 | NOD 11 97 | TLFL 11-15 | | INBC 11-49 | NOP 11-37 | TSTQ 11-50 | | INBC 11-49 | NOP 11-55 | TVA 44 40 | | INIEC 11 40 | PCI 11_47 | TXA 11-43 | | INEC 11-49 | TOD II 4/ | TYA 11-43 | | INEN 11-49 | PIDA 11-26 | VIRY 11-29 | | INIH 11 30 | PIDI. 11-26 | VIKI 11-29 | | 11V11 11-00 | DIMA 11 06 | WAIT 11-49 | | INT 11-21 | PIMA 11-20 | WCS 11-39 | | INTA 11-21 | PIML 11-26 | VV CD 11 00 | | INITEL 44 00 | DDTN 11 48 | XAD 11-10 | | IN1L 11-22 | FIXIN II-40 | XBTD 11-11 | | IRS 11-53 | PTLB 11-37 | YCA 11 10 | | IDV 11 52 | RBO 11-50 | XCA 11-43 | | IIIV 11-00 | DCD 44 04 | XCM 11-40<br>XCM 11-11<br>XDTB 11 12 | | ITBL 11-35 | KCB 11-31 | VDTR 11 12 | | IMP 11-46 | RMC 11-28 | XDTB 11-12<br>XDV 11-12 | | 10T 11 16 | DDCT 11 20 | XDV 11-12 | | JS1 11-40 | KK31 11-30 | XEC 11-49 | | ISX 11-47 | RSAV 11-38 | AED 11 10 | | ICVR 11 47 | RTO 11_50 | XED 11-13 | | JOND 11-4/ | R1Q 11 00 | XMP 11-13 | | JSY 11-47 | S1A 11-26 | V3 (\$1 11 14 | | LCEQ 11-33 | S2A 11-27 | XMV 11-14 | | I COE 44 99 | CAD 11 59 | XVRY 11-29 | | | | 7CM 11 F | | LCGT 11-33 | SAS 11-53 | ZCM 11-5 | | | SBL 11-27 | ZED 11-5 | | LCLE 11-33 | | ZFIL 11-6 | | LCLT 11-33 | SCB 11-31 | | | LCNE 11-33 | SGT 11-54 | ZMV 11-6 | | | | ZMVD 11-7 | | LDA 11-40 | SKP 11-54 | | | LDC 11-5 | SLE 11-54 | ZTRN 11-7 | | | SLN 11-55 | Values, output 18-4 | | LDL 11-40 | | VAPPLB library, use with | | LDLR 11-41 | SLZ 11-55 | | | LDX 11-41 | SMCR 11-29 | SEG 5-2, 5-3 | | | | VAPPLB, system library 8-1 | | LDY 11-41 | SMCS 11-29 | | | LEQ 11-33 | SMI 11-55 | Variables, macro 17-2 | | | RMQ 11-54 | Verify the XIS board (Prime 500), | | LF 11-34 | 1717 11-04 | | | LFEQ 11-34 | SNS 11-54 | XVRY, (V) 11-29 | | • | SNZ 11-55 | Verify XIS, XVRY, (I) 12-14 | | LFGE 11-34 | | Verify XIS, XVRY, (I) 12-17 | | LFGT 11-34 | SPL 11-55 | . <del>-</del> | | LFLE 11-34 | SR2 11-55 | Verify, VIRY, (I) 12–14 | | | SR3 11-55 | Verify, VIRY, (SRV) 11-29 | | LFLI 11-15 | | | | LFLT 11-34 | SR4 11-55 | VFD pseudo-operation 16–11 | | | | | FDR 3059 | VI decimal control word format 9-2 keys 9-12 queue control block 9-7 registers 9-9 subroutine call conventions 8-3 Virtual address space 4-5 Virtual loading 4-5 VIRY (I) 12-14 VIRY (SRV) 11-29 VPSD (virtual symbolic debugger) 18-1, 18-3, 18-4 command summary 21-1 terminators 21-1 using 18-3 VPSD16 18-3 VSRTLB library, use with SEG 5-2, 5-3 VSRTLB, system library 8-1 | Zero memory halfword, ZMH, (I) 12-5 Zero, VPSD 21-6 ZFH, fill character field, (I) 12-4 ZFIL, fill field, (V) 11-6 ZM, zero memory fullword, (I) 12-5 ZMH, zero memory halfword, (I) 12-5 ZMV, move character field, (I) 12-4 ZMV, move character field, (V) 11-6 ZMVD, move equal length fields, (I) 12-4 ZMVD, move equal length fields, (V) 11-7 ZTRN, translate character field, (V) 11-7 ZTRN, translate character fields, (I) 12-4 | |----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | W WAIT (I) 12-20 WAIT (V) 11-49 WCS (I) 12-17 WCS (RV) 11-39 Writable control store, WCS, (I) 12-17 Writable control store, WCS, (RV) 11-39 Writing and debugging a program, example 2-5 Writing V or I mode code in PMA 14-8 | | | X X (I) 12-15 XAC pseudo-operation 16-7 XAD (I) 12-5 XAD (V) 11-10 XB% assembler notation 15-8 XBTD (I) 12-5 XBTD (V) 11-11 XCA (SRV) 11-43 XCB (SRV) 11-43 XCB (SRV) 11-43 XCM (I) 12-5 XCM (V) 11-11 XDTB (I) 12-5 XDTB (V) 11-12 XDV (I) 12-5 XDV (V) 11-12 XEC (RV) 11-49 XED (I) 12-5 XED (V) 11-13 XH (I) 12-16 XMP (I) 12-5 XMP (V) 11-13 XMV (I) 12-5 XMV (V) 11-14 XSET pseudo-operation 16-21 XVRY (V) 11-29 XVRY (I) 12-14, 12-17 | | | Z ZCM (I) 12-4 ZCM (V) 11-5 ZED (I) 12-4 ZED (V) 11-5 Zero memory fullword, ZM, (I) 12-5 | | # **AIDUS** ## Change sheet package This is your AIDUS Change Sheet package for FDR3059, **The Assembly Language Programmer's Guide.** It contains replacement pages to update your book to Master Disk Revision 17. Two types of changes are indicated on these change pages. Changes that are specific to Revision 17 are indicated by the following symbol: <1>. The bar extending up and down from the symbol, points out the overall area where Revision 17 changes were made. Other changes, (errors fixed, information missing at Revision 16 or earlier, or editorial changes) are shown by a simple bar in the inner margin. All pages with changes of either type are now dated 1 january 1980 in the folio line. Change Sheet Package Number: COR3059-001 **Date:** January, 1980 **Revision Number:** 17 Number of pages enclosed: 14 Pages with changes: 8 **List of pages enclosed** (pages with changes are underlined): 4-3, 4-4, 5-9, 5-10, 5-11, <u>5-12</u>, <u>5-13</u>, 6-0, <u>6-1</u>, 6-2, <u>8-1</u>, 8-2, 16-19, <u>16-20</u> Copyright© 1980 by Prime Computer, Incorporated Published by Prime Computer, Incorporated Technical Publications Department 500 Old Connecticut Path Framingham, MA 01701 The information contained on these change pages is subject to change without notice and should not be construed as a commitment by Prime Computer, Incorporated. Prime Computer, Incorporated assumes no responsibility for any errors that may appear in this package. PRIME and PRIMOS are registered trademarks of Prime Computer. PRIMENET and THE PROGRAMMER'S COMPANION are trademarks of Prime Computer, Inc. Printing date: January, 1980 All correspondence on suggested changes to this document should be addressed to: Rosemary Shields Technical Publications Department Prime Computer, Inc. 500 Old Connecticut Path Framingham, MA 01701 - 3. Other Prime libraries (LI filename). - 4. Standard FORTRAN library (LI). #### Loading library subroutines Standard FORTRAN mathematical and input/output functions are implemented by subroutines in the library file FTNLIB in the LIB UFD. The appropriate subroutines from the file are loaded by the LIBRARY command given without a filename argument. If subroutines from other libraries are used, such as MATHLB, SRTLIB, or APPLIB, additional LIBRARY commands are required which include the desired library as an argument. #### LOAD MAPS During loading the loader collects information about the results of the load process, which can be printed at the terminal (or written to a file) by the MAP command: #### MAP [pathname] [option] The information in the map can be consulted to diagnose problems in loading, or to optimize placement of modules, linkage areas and COMMON in complex loads. Load information is printed in four sections, as shown in Figure 4-1. The amount of information printed is controlled by MAP option codes such as: | Option | Load Map Information | | |--------------|----------------------------------------------------------------------|--| | None, 0 or 4 | Load state, base area, and symbol storage; symbols sorted by address | | | 1 | Load state only | | | 2 | Load state and base areas | | | 3 | Unsatisfied references only | | | 6 | Undefined symbols, sorted in alphabetical order | | | 7 | All symbols, sorted in alphabetic order | | #### Load state The load state area shows where the program has been loaded, the start-of-execution location, the area occupied by COMMON, the size of the symbol table, and the UII status. All locations are octal numbers. - \*START: The location at which execution of the loaded program will begin. The default is '1000. - \*LOW: The lowest memory image location occupied by the program. Executable code normally starts at '1000, but sector 0 address links (if any) begin at '200. - \*HIGH: The highest memory image location occupied by the program (excluding any area reserved for initialized COMMON). - \*PBRK: "Program Break": The next available location for loading. It normally is the location following the last loaded module, but can be moved by PBRK or the LOAD family of commands. - \*CMLOW: The low end of COMMON. - \*CMHGH: The top of COMMON. - \*SYM: The number of symbols in the loader's symbol table. This is usually of not concern unless the symbol space crowds out the last remaining runfile buffer area. (There is room for about 4000 symbols before this is a risk.) \*UII: A code representing the hardware required to execute the instructions in loaded modules. Codes and other information are described later in this section. #### Base areas The base area map includes the lowest, highest and next available locations for all defined base areas. Each line contains four addresses as follows: | *BASE | XXXXXX | YYYYYY | ZZZZZZ | WWWWW | |--------|--------|----------------|-----------------|----------------------| | XXXXXX | Lowe | est location d | efined for thi | is area | | YYYYYY | Next | available lo | cation if start | ing up from XXXXXX | | ZZZZZZ | Next | avaiľable lo | cation if start | ing down from WWWWWW | | wwwww | W High | est location o | defined for th | iis area | #### Symbol storage The symbol storage listing consists of every defined label or external reference name printed four per line in the following format: #### namexx NNNNNN or #### \*\*namexx NNNNNN **NNNNNN** is a six-digit octal address. The \*\* flag means the reference is unsatisfied (i.e., has not been loaded). Symbols are listed by ascending address (default) or in alphabetical order (MA 6 or MA 7). The list may be restricted to unsatisfied references only (MA 3 or MA 6). #### COMMON blocks The low end and size of each COMMON area are listed, along with the name (if any). Every map includes a reference to the special COMMON block LIST, defined as starting at location 1. #### LOADER CONCEPTS When standard loading goes well, the user can ignore most of the loader's advanced features. However, situations can arise where some detailed knowledge of the loader's tasks, can optimize size or performance of a runfile, or even make a critical load possible. From that viewpoint, the main tasks of the loader are: - Convert block-format object code into a run-time version of the program (executable machine instructions, binary data and data blocks). - Resolve address linkages (translate symbolic names of variables, subroutine entry points, data items etc. into appropriate binary address values). - Perform address resolution (discussed later). - Detect and flag errors such as unresolved external references, memory overflow, etc. - Build (and, on request, print) a load map. The map may also be written to a file. - · Reserve COMMON areas as specified by object modules. - Keep track of runfile's hardware execution requirements and make user aware of need to load subroutines from UII library. #### SEG-LEVEL COMMANDS Commands at SEG level are entered in response to the "#" prompt. #### DELETE [pathname] Deletes a saved SEG runfiles. #### **HELP** Prints abbreviated list of SEG commands at terminal. #### [V]LOAD[\*] [pathname] Defines runfile name and invokes virtual loader for creation of new runfile (if name did not exist) or appending to existing runfile (if name exists). If **pathname** is omitted, SEG requests one. ## MAP pathname-1 [pathname-2] [map-option] Prints a loadmap of runfile (pathname-1 or current loadfile (\*)) at terminal or optional file (pathname-2). #### Option Load Map information - 0 Full map (default) - 1 Extent map only - 2 Extent map and base areas - 3 Undefined symbols only - 4 Full map (identical to 0) - 5 System programmer's map - 6 Undefined symbols, alphabetical order - 7 Full map, sorted alphabetically - 10 Symbols by ascending address - 11 Symbols alphabetically #### MODIFY [filename] Invokes MODIFY subprocessor to create a new runfile or modify an existing runfile. #### PARAMS [filename] Displays the parameters of a SEG runfile. #### **PSD** Invokes VPSD debugging utility. #### **QUIT** Returns to PRIMOS command level and closes all open files. #### RESTORE [pathname] Restores a SEG runfile to memory for examination with VPSD. #### RESUME [pathname] Restores runfile and begins execution. #### SAVE [pathname] Synonym for MODIFY. ### SHARE [pathname] Converts portions of SEG runfile corresponding to segments below '4001 into R-mode-like runfiles. #### SINGLE [pathname] segno Creates an R-mode-like runfile for any segment. ## TIME [pathname] Prints time and date of last runfile modification. #### **VERSION** Displays SEG version number. **VLOAD** See LOAD. #### LOAD SUBPROCESSOR COMMANDS ## ATTACH [ufd-name] [password] [ldisk] [key] Attaches to directory. #### AUTOMATIC base-area-size Automatically places base areas between procedures. ## A/SYMBOL symbolname [segtype] segno size Defines a symbol in memory and reserves space for it using absolute segment numbers. Relocates COMMON using absolute or relative segment numbers. Continues a load using parameters of previous load command. #### Note D/ and F/ may be combined, as in D/F/LI. #### EXECUTE [a] [b] [x] Performs SAVE and executes program. Forceloads all routines in object file. #### IL [addr psegno lsegno] Loads impure FORTRAN library IFTNLB #### INITIALIZE [pathname] Initializes and restarts load subprocessor. ### LIBRARY [filename] [addr psegno lsegno] Loads library file (PFTNLB and IFTNLB if no filename specified). #### LOAD [pathname] [addr psegno lsegno] Loads object file. #### MAP [pathname] option Generates load map (see SEG-level MAP command). $$\mathbf{MIXUP}\left\{ \begin{bmatrix} \mathbf{ON} \\ \mathbf{OFF} \end{bmatrix} \right\}$$ Mixes procedure and data in segments and permits loading of linkage and common areas in procedure segments. Not reset by INITIALIZE. ## MV [start-symbol move-block desegno] Moves portion of loaded file (for libraries). If options are omitted, information is requested. #### **OPERATOR** option Enables or removes system privileges 0=enable, 1=remove. Caution: this command is intended only for knowledgeable creators of specialized software. #### PL [addr psegno [segno] Loads pure FORTRAN library, PFTNLB. Loads on a page boundary. The **options** are: PR=procedure only, DA=link frames only, none =both procedure and link frames. #### QUIT Performs SAVE and returns to PRIMOS command level. #### **RETURN** Performs SAVE and returns to SEG command level. #### RL pathname [addr psegno lsegno] Replaces a binary module in an established runfile. #### R/SYMBOL symbol-name [segtype] segno size Defines a symbol in memory and reserves space for it using relative segment assignment. (Default=data segment). Saves the results of a load on disk. #### SETBASE segno length Creates base area for desectorization. Splits segment into data and procedure portions. Formats 2 and 3 allow R mode execution if all loaded information is in segment 4000. #### SS symbol-name Saves symbol; prevents XPUNGE from deleting symbol-name. #### STACK size Sets minimum stack size. Defines a symbol at a location and/or assigns a value of an already defined symbol or a constant. Controls use of sector zero base area in procedure segments. Loads an object file in specified absolute segments. #### XP dsymbol dbase Expunges symbol from symbol table and deletes base information. #### symbol Action - Delete all defined symbols—including COMMON area. - 1 Delete only entry points, leaving COMMON areas. #### dbase Action - 0 Retain all base information. - 1 Retain only sector zero information. - 2 Delete all base information. #### MODIFY SUBPROCESSOR COMMANDS #### NEW pathname Writes a new copy of SEG runfile to disk. ## PATCH segno baddr taddr Adds a patch (loaded between baddr and taddr) to an existing runfile and saves it on disk. #### **RETURN** Returns to SEG command level. Specifies stack size (ssize) and location. esegno specifies an extension stack segment. #### START segno addr Changes program execution starting address. #### WRITE Writes all segments above '4000 of current runfile to disk. This section treats the following topics: - Execution of program memory images saved by the linking loader. - Execution of segmented runfiles saved by SEG's loader. - Installation of programs in the command UFD (CMDNC0). - Use of run time. #### **EXECUTION OF UNSEGMENTED RUNFILES** Use the PRIMOS RESUME command to execute an unsegmented runfile: #### **RESUME** pathname where pathname is an R-mode runfile in the current UFD. Programs which are resident in the user's memory may be executed by a START command: #### **START** #### **RESUME** RESUME brings the memory-image program **pathname** from the disk into the user's memory, loads the initial register settings, and begins execution of the program. Its format is: #### RESUME pathname #### Example: | OK, R *TEST<br>GO<br>THIS IS A TEST | User requests program Execution begins Output of program | |-------------------------------------|----------------------------------------------------------| | OK, | PRIMOS requests next command | #### Note As of Rev. 17 PRIMOS no longer prints GO in response to a command. RESUME should not be used for segmented (64V or 32I mode) programs; use the SEG command (discussed later) instead. #### **START** Once a program is resident in memory (e.g., by a previous RESUME command) you can use START to initialize the registers and begin execution. Its format is: #### START [start-address] Upon completion of the program, control returns to PRIMOS command level. #### **EXECUTION OF SEGMENTED RUNFILES** Use the SEG command to begin execution of a segmented program; e.g. **SEG pathname** where **pathname** is a SEG runfile. SEG loads the runfile into segmented memory and starts execution. SEG should be used for runfiles created by SEG's Loader; it should not be used for program memory images created by the LOAD utility. #### Example: | OK, SEG #TEST<br>GO<br>THIS IS A TEST | user requests program execution begins output of program | |---------------------------------------|----------------------------------------------------------| | OK, | PRIMOS requests next command | Upon completion of program execution, control returns to the PRIMOS command level. You may restart a SEG runfile by the command: S 1000, provided both the SEG runfile and the copy of SEG used to invoke it are in memory. #### INSTALLATION IN THE COMMAND UFD (CMDNCO) Run-time programs in the command UFD (CMDNC0) can be invoked by keying in the program name alone. This feature of PRIMOS is useful if a number of users invoke this program. Only one copy of the program need reside on the disk in UFD CMDNC0. Even more space is saved during execution by multiple users if the program uses shared code (64V and 32I mode only). #### Program memory images saved by LOAD Installation in the command UFD is extremely simple, providing you have access to the password. The runtime version of the program is copied into UFD CMDNC0 using PRIMOS' FUTIL file handling utility. Example: Assume you have written a utility program called FARLEY. This utility acts as a "tickler" for dates. Using FARLEY, each user builds a file with important dates. The FARLEY utility program, upon request, prints out upcoming events or occasions of interest to the user. #### Note This utility does not necessarily actually exist; it is used as a plausible example. First, assemble the program. ``` OK, PMA FARLEY -64R Assemble in 64R mode GO ØØØØ ERRORS (PMA-REV 16.2)ASSEMBLER MESSAGE OK, LOAD Invoke the Loader GO $LO B_FARLEY Load the object file; the default name is used $ Load other required modules . ``` FDR 3059 6-2 1 March, 1979 Most of the commonly used subroutines - I/O, math functions and EXIT, are either embedded in the operating system or are in one of the FORTRAN libraries. LOAD and SEG automatically load the appropriate library when you type the command LI during a loading sequence. Other libraries, such as APPLIB and MATHLIB require the specification of their name following LI — e.g. LI APPLIB causes the application library to be searched for unresolved references. Table 8-1 lists the commonly available system libraries. See the Reference Guide, PRIMOS Subroutines for complete descriptions of the system subroutines. All routines, regardless of mode, should use the CALL pseudo-operation to call subroutines. S and R-mode arguments use DAC pointers; V, and I-mode arguments use AP pointers (see Section 16 for the DAC and AP pseudo-operation formats). Figure 8-1 illustrates the SR calling sequences and associated subroutine code; Figure 8-2 illustrates VI calling sequences and associated subroutine code. FORTRAN Library pure pro- | | IFTNLB | cedures<br>FORTRAN Library impure<br>cedures | |------------|-------------------|---------------------------------------------------------| | $\bigcirc$ | PLIGLB<br>NPFTNLB | PL/I V and I Mode Library<br>FORTRAN Library V-Mode, Pt | | | APPLIB | Application Library | Table 8-1. System Libraries Name **FTNLIB** **PFTNLB** Description FORTRAN Library Mode R $\mathbf{v}$ pro- | No Arguments | Main Program One Argument | Two or More Arguments | |-------------------------------|--------------------------------------------|------------------------------------------------------------------------------------------| | | | | | | | | | CALL SUBX | CALL SUBX<br>DAC A | CALL SUBX DAC A DAC B DAC C | | | | | | | | DAC Ø | | | Subro | outine | | | | | | ENT SUBX<br>REL | ENT SUBX<br>REL | ENT SUBX<br>REL | | | | | | SUBX DAC ** first instruction | SUBX DAC ** CALL F\$AT DEC 1 APTR DAC** | SUBX DAC ** CALL F\$AT DEC 3 APTR DAC ** BPTR DAC ** CPTR DAC ** first instruction | | | | | | | JMP SUBX,* | JMP SUBX,* | | | | | | ( | <b>Note</b><br>CALL SUBX is equivalent | to: | | | EXT SUBX<br>JST SUBX | | | | | | | | | | | Figure 8-1. SR Subroutine C | All Conventions | | external. Unlike EXT, there is no conflict between a local variable and a CALL operand with the same symbol. The operand must contain a single symbol (not an expression) of up to 6 characters, of which the first must be alphabetic. A ,1 for indexing and \* for indirect addressing is optional. In 64V and 32I modes, CALL generates a PCL instruction to an external symbol. ## DYNT address-expression Defines a direct entry point into the operating system. System libraries only. ## [label] ECB entry-point, [link base], displacement, n-arguments [, stack-size] [, keys] Generates an entry control block to define a procedure entry. It must go in the linkage frame with the subroutine entry point pointing to the ECB. | Parameter | Meaning | |--------------|----------------------------------------------------------------------------------------------| | entry-point | Procedure relative value; entry point for subroutine. | | link-base | Link base register value. | | displacement | Displacement in stack frame for argument list. May be stack relative or absolute expression. | | n-arguments | Number of arguments expected; default is zero. | | stack-size | Initial stack frame size. Default is maximum area specified in DYNM statements. | | keys | CPU keys for procedure. Default is 64V addressing mode, all other keys zero. | #### For example: | | ENT | <b>ECBNAM</b> | |--------|------|---------------| | LAB1 | LDA | ='123 | | | LINK | | | ECBNAM | ECB | LAB1 | | | END | | If the default value for a parameter is desired, the parameter may be omitted, leaving only its delimiting comma. Any string of trailing commas may be omitted. #### Note The main program — that which you call PRIMOS level using SEG#Name — is a subroutine to SEG and must, therefore, have an ECB and the ECB name on the END statement. It need not have an ENT because SEG will give a dummy entry point name to a routine called at this level. ## ► [label] EXT symbol Identifies external variables. The names appearing in the operand of this statement are flagged as external references. Whenever other statements in the main program reference one of these names, a special block of object text is generated that notifies the loader to fill in the address properly. The assembler fills the address fields with zeroes. Names defined by the EXT pseudo-operations are unique only in the first 6 characters (loader restriction) and should not appear in a label field internal to the program. ## ▶ [label] SUBR symbol-1 or ENT symbol-1 [ , symbol-2] Link subroutine entry points to external names used in CALL, XAC or EXT statements in calling programs. SUBR and ENT are identical in effect. **symbol-1** is the external name used by calling program, whereas, **symbol-2** is the entry name used in subroutine, if different from symbol-1. All SUBR and ENT pseudo-operations must appear before any generated code. Allows long external names up to eight characters to be generated by the assembler. Must follow SEG or SEGR but precede any generated code. #### STORAGE ALLOCATION PSEUDO-OPERATIONS (SA) Control the allocation of storage within the program address space. | Name | Function | Restriction | |------|-------------------------------------|-------------| | BSS | Allocate block starting with symbol | | | BES | Allocate block ending with symbol | | | BSZ | Allocate block set to zeroes | | | COMM | FORTRAN compatible COMMON | | Allocates a block of words of the size specified in the **absolute-expression** starting at the current location count. If there is a label, it is assigned to the first word of the block (BSS and BSZ) or to the last word of the block (BES). For BSZ, all words within the block are set to zeroes. ## [label] COMM symbol [(absolute-expression)] Defines FORTRAN-compatible named COMMON areas. These areas are allocated by the loader. The **label** assigns a name to the block as a whole, and the operand field specifies named variables or arrays within the block. Additional COMM statements with the same block name are treated as continuations. **symbol** alone reserves a single location: the optional **absolute-expression** reserves locations equal to its value. In SEG mode, the loader sets up a 32-bit indirect pointer in the linkage segment which points to the common area. #### SYMBOL DEFINING PSEUDO-OPERATIONS (SD) Variables used as address symbols are usually defined when they appear in the label field of an instruction or pseudo-operation statement. Symbols so defined are given the relocation mode and value of the program counter at that location. The EQU, SET and XSET statements make it possible to equate symbols to any numerical value, including ones that lie outside the range of addresses in a program. | Name | Function | Restrictions | |------|------------------------|--------------| | DYNM | Declare stack relative | R and V only | | EQU | Symbol definition | | | SET | Symbol definition | | | XSET | Symbol definition | | ## **USER SURVEY** Tell us how we're doing, and we'll send you a free Programmer's Companion. | Company or School | | | | |----------------------------------------------------------------------------------------------------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------|--|--| | Address | | | | | City, State, Zip | | | | | 1 What is your ish title on (marks 2 | | | | | <ul><li>1. What is your job title or function?</li><li>2. What specific task describes what you do?</li></ul> | | | | | <ul><li>3. Does your company or school own a Prime computer?</li><li>a. If YES, which model?</li><li>b. Is it networked with other Prime</li></ul> | ☐ YES ☐ NO ☐ 450 ☐ 550 ☐ 650 ☐ 750 ☐ OTHER | | | | computers? c. Is it networked with any of these? d. Which of these software packages do | ☐ YES ☐ NO ☐ IBM ☐ CDC ☐ UNIVAC ☐ HONEYWELL | | | | you use? | FORTRAN COBOL BASIC/VM FORTRAN 77 PL/I-G POWER MIDAS DBMS SPSS RPGII FORMS PRIMENET RJE PASCAL OAS DBG DPTX | | | | <ul><li>e. Have you read any other Prime documents?</li><li>f. If YES, which ones?</li></ul> | ☐ YES ☐ NO | | | | 4. Are you presently evaluating Prime? Is the documentation playing a part? 5. What book are you reviewing? | YES NO YES NO | | | | 6. My initial reaction to this book was: | ☐ EXCELLENT ☐ GOOD ☐ FAIR ☐ VERY GOOD ☐ FAIR | | | | 7. After reading it my reaction was: If BETTER or WORSE why? | BETTER THE SAME WORSE | | | | 8. How often have you used this book? | ☐ EVERY DAY ☐ FAIRLY OFTEN ☐ VERY OFTEN ☐ JUST GOT IT | | | | 9. Did the book have the content you expected? If NO, why? | ☐ YES ☐ NO | | | | J. Did you find the organization useful? If NO, why? | ☐ YES ☐ NO | | | | 11. How did you find the examples? | ☐ TOO MANY ☐ ABOUT RIGHT ☐ TOO FEW | | |----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--| | 12. How did you find the illustrations? | ☐ TOO MANY ☐ ABOUT RIGHT ☐ TOO FEW | | | 13. Could you locate the information you needed? | ☐ YES ☐ NO | | | 14. Was the index adequate? | ☐ YES ☐ NO | | | 15. Please evaluate our writing style and edit quality? | | | | <ul><li>a. Clarity</li><li>b. Tone</li><li>c. Technical level</li><li>d. General writing quality</li><li>e. Editorial quality</li></ul> | □ VERY CLEAR □ AVERAGE □ UNCLEAR □ CORRECT □ NEUTRAL □ STILTED □ TOO HIGH □ ABOUT RIGHT □ TOO LOW □ EXCELLENT □ AVERAGE □ FAIR □ POOR □ EXCELLENT □ AVERAGE □ FAIR □ POOR | | | <b>16.</b> Which of these manufacturers documentation have you used the most? | □ IBM □ DIGITAL □ DG □ HP □ CDC □ UNIVAC □ HONEYWELL □ BURROUGHS □ WANG □ GE □ XEROX □ ———— □ MUCH BETTER □ A LITTLE WORSE | | | How is Prime compared to theirs? | <ul> <li>MUCH BETTER</li> <li>A LITTLE WORSE</li> <li>MUCH WORSE</li> <li>SAME</li> </ul> | | | Any comment on your rating? | | | | <ul><li>17. Please evaluate the graphic quality:</li><li>a. Rate the general presentation</li></ul> | ☐ EXCELLENT ☐ GOOD ☐ POOR ☐ VERY GOOD ☐ FAIR | | | <ul><li>b. Do you like the paper color?</li><li>c. Did you find any quality defects?</li><li>d. Do you like the way we've used color for abbreviations and user input?</li></ul> | ☐ YES ☐ NO ☐ YES ☐ NO ☐ YES ☐ NO | | | e. Did the shading over the tables and<br>charts make them EASIER or<br>HARDER to read? | ☐ EASIER ☐ HARDER | | | f. Do you like the Programmer's Companion concept? | YES NO HAVENT SEEN ONE | | | g. Which form of bindery do you find most useful? | ☐ BOUND ☐ LOOSE-LEAF | | | <b>18.</b> Do you know about the AIDUS program? | ☐ YES ☐ NO | | | 19. Any other comments: | | | | 27.12., 03.00. | | | | | | | | | | | | | | | | | | | | _ | | | | | | | | | | | | | | | | <b>20.</b> What book don't we offer that you'd like to see? | | | |----------------------------------------------------------------------------|-----------------|-----------------| | Thank you for filling out the survey.<br>Check off which Programmer's Com- | | | | panion you would like to receive. | ☐ PRIMOS | ☐ FORTRAN | | | ☐ FORTRAN 77 | ☐ BASIC/VM | | | ASSEMBLY | POWER | | | ☐ ADMINISTRATOR | WORD PROCESSING | | | | | | · · · · · · · · · · · · · · · · · · · | ASSEMBLY | POWER | . NO POSTAGE NECESSARY IF MAILED IN THE UNITED STATES First Class Permit #531 Natick, Massachusetts 01760 ## **BUSINESS REPLY MAIL** Postage will be paid by: # PR1ME Attention: Technical Publications Bidg 10B Prime Park, Natick, MA 01760