# CYBER 180 II ASSEMBLER for CPU and IOU # EXTERNAL REFERENCE SPECIFICATION (S5233) This product is intended for used only as described in this document. Control Data cannot be responsible for the proper functioning of undescribed features and parameters. (c) Copyright Control Data Corporation 1985 CYBER 180 II Assembler ERS # REVISION DEFINITION SHEET | REV | DATE | DESCRIPTION | |-----|--------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | A | 05/30/80 | Original, for CPU Assembler only. | | 8 | <br> 09/15/80<br> | Revised for comments against REV. A. | | c | 05/05/81 | Revised to add IOU mnemonic instructions, several appendicies, and other corrections. | | D | <br> 08/14/81<br> | Revised to correct comments against REV. C. | | E | 12/01/81 | Revised to corect grammatical errors, delete obsolete pseudo-op GEN from examples, correct errors in descriptions of the IOU instructions, update titles and update this revision page. Since revision D of this document was never submitted to DCS the revision bars have been generated relative to revision C. | | F | 04/11/85 | Revised to include vector instructions for the Cyber 180-990. Appendix A, which describes the command parameters, changed to include the LIST_OPTIONS parameter. | | | | | CYBER 180 II Assembler ERS Rev: F 1.0 SCOPE ### 1.0 SCOPE This document is the external specification for the CYBER 180 II Assembler. This assembler runs on the CYBER 180 machine in CYBER 180 mode and assembles either CYBER 180 CPU or CYBER 180 IOU code. The object program output of the Assembler is compatible with the NOS/VE loader. The II Assembler is the language successor to the CI Assembler described in the ARH1693 ERS document. # 1.1 APPLICABLE DOCUMENTS The following documents reference related material which would be of value to the reader. - CYBER 180 Mainframe Model Independent GDS (MIGDS), Rev. S (ARH 1700). - CYBER 180 CI CPU Assembler ERS (ARH 1693). - NOS/VE Command Interface - NDS/VE Program Interface Rev: F # 2.0 LANGUAGE STRUCTURE ### 2.0 LANGUAGE\_SIRUCIURE A CYBER 180 Assembly language source program consists of a sequence of statements which contain symbolic machine instructions, pseudo instructions, and comment lines. With the exception of the comment lines, each statement consists of a label field, an operation field, argument field(s), and a comments field. Each field is terminated by one or more blank characters. The size of the argument field is restricted by the maximum statement size only. Statement format is essentially free field, except for the label field which must start in column 1. A statement consists of one or more physical lines of data. A line may be up to 255 characters long and the Assembler will print the entire line at the rate of 88 characters per print line. Assembler will only examine the first 88 characters of a line. Information after column 88 is presumed to be comments. The language also supports a procedure mechanism with parameter capability. Each time the name of the procedure is referenced, the body of the procedure will be inserted in the code. This will be further explained in the section entitled 'Procedures'. ### 2.1 SIAIEMENI A statement is an ordered group of fields starting (from left to right) with one Label field followed by Operation and Argument fields and one Comments field. The number of fields allowed in a statement is not limited. The comments field is optional, but the other fields must be accounted for by field delimiters. A statement may be continued onto more than one line, but no more than one statement is allowed per line. # 2.1.1 FIELD A Field is a consecutive group of characters starting with a non-blank character and terminated by a blank character, end-of-line, or character position 88 of the line, whichever occurs first. The only exceptions to this definition are: a) Blanks may appear freely in a CHARACTER STRING without CYBER 180 II Assembler ERS Rev: F # 2.0 LANGUAGE STRUCTURE 2.1.1 FIELD causing field termination. - b) Blanks may appear freely in the COMMENTS field. - c) If a continuation character ";" is encountered within a field which is not a COMMENTS or CHARACTER STRING, the field is continued on the next line. - d) Extra or spurious fields in a statement are not detected and no error is diagnosed. ### 2.1.2 SUBFIELD A Subfield is a consecutive group of characters starting with a non-blank character and terminated by a comma "," or by End-Of-Field, whichever occurs first. A field may have one or more subfields. The only exceptions to this definition are: - a) Commas may appear freely in a CHARACTER STRING without causing subfield termination. - b) Commas may appear freely in the COMMENTS field. - c) If a continuation character ";" is encountered within a subfield, the subfield is continued on the next line. - d) Extra or spurious subfields in a field are not detected and no error is diagnosed. ### 2.1.3 NULL FIELD The absence of a field or subfield is automatically detected by the Assembler based on the number of fields. An OPERATION field <u>must\_not\_be\_Null</u> and must have as many ARGUMENT fields following it as required by its defining pseudo instruction or PROCEDURE, although the number of ARGUMENT fields can be variable and depend on some other field. The rules for NULL field: a) A blank in character position 1 of a line indicates the absence of the LABEL field on that line. The next non-blank character on the line, excluding comments, is accepted as part of an OPERATION field. CYBER 180 II Assembler ERS Rev: F 2.0 LANGUAGE STRUCTURE 2.1.3 NULL FIELD \*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\* - b) An OPERATION field cannot be blank. - c) Two consecutive commas indicate the presence of a null subfield. - d) One comma "," followed by a blank indicates (as specified) end-of-subfield <u>and</u> end-of-field and can be used to delimit trailing Null subfields. The configuration blank, blank indicates a Null field with two Null subfields. # 2.2 COMMENIS Comments may start in any column, but are always the last field on a line, and end at end of line. All comments must begin with a period. Scanning by the Assembler stops when a period preceded by a blank or a period in column 1 is encountered, thus comments may contain any Ascii character, including characters that would otherwise have special meaning (e.g. the semicolon which denotes continuation when used outside of comments). When a statement is continued to the next line, comments may appear after the continuation character on the line being continued. ### 2.2.1 STATEMENT CONTINUATION Normally, column 88 terminates a source statement that has not otherwise terminated. However, a statement that cannot be contained in the first 88 characters can be continued on successive lines by placing a semi-colon ";" at the continuation point. A statement may only be broken between fields, subfields, or terms of an expression. A term may not be broken onto 2 lines (e.g. a long character string must fit on one line). The statement will be continued at the first non-blank character on the next line at or after character position 2. Character position 1 of all continuation lines must contain a blank. The continuation character, if used, must appear at or prior to character position 88. The only exceptions to this definition are: - a) Semicolons may appear freely in a CHARACTER STRING without causing continuation. This implies that character strings cannot be continued across statements. - b) Semicolons may appear freely in a COMMENTS field without causing continuation. Comments cannot be continued across ### CYBER 180 II Assembler ERS Rev: F 2.0 LANGUAGE STRUCTURE 2.2.1 STATEMENT CONTINUATION statements. ### 2.3 CHARACIER\_SEI The Assembler recognizes the following, graphic charactersubset of the NOS/VE ASCII character set as input: Alphabetic A through Z (upper or lower case) \$ a # \_: Numeric 0 through 9 Special Characters: # Blank or Space - + Add - Subtract or Unary Minus - \* Multiply - / Divide or Logical NOT - = Equal - < Less Than - > Greater Than - & Logical AND - ! Logical Inclusive OR (vertical bar) - Logical Exclusive OR (double vertical bar) - <= Less Than or Equal To</p> - >= Greater Than or Equal To - /= Not Equal To - Period or Decimal Point - Comma - ( Left Parenthesis - ) Right Parenthesis - [ Left Bracket - 1 Right Bracket - Apostrophe - : Continuation - \*\* Shift In addition to the characters listed above, the Assembler accepts the following characters as part of program comments or as part of a Character String: # " \ ^ ! ? % { } ~ The Assembler distinguishes between upper and lower case characters only when used within character strings enclosed by quotes. CYBER 180 II Assembler ERS Rev: F 2.0 LANGUAGE STRUCTURE 2.3 CHARACTER SET Other ASCII characters appearing before the comment field are diagnosed as an error. ### 2.4 SYMBOL DEFINITION A symbol is a set of alphabetic or numeric characters that identifies a byte address or a value and its attributes. The symbol must start with any alphabetic character, and the symbol can be a maximum of thirty-one (31) characters long, and cannot include any of the special characters. The colon (:) may not be used as a character in a user defined symbol, it is reserved for language defined names. Symbols are defined when they are used in the label field of any statement (CPU, IDU, or pseudo instruction), except for some pseudo instructions which ignore the label field and other pseudo instructions which use the label field for other purposes. ### **EXAMPLES:** P | Legal | Illegal | |---------|---------| | Symbols | Symbols | First character must be alphabetic. Exceeds 31 characters Contains plus sign ABCDEFGHIJKLMNOPQRSTUVWXYZ012345 PROGRAM ABE+15 # 2.4.1 LINKAGE SYMBOLS 543 Modules (assembly units) can be linked to other modules (assembly/compilation units) through symbols defined as entry points. Entry points in the current module are declared with a DEF or DEFG pseudo instruction. This allows the entry point to be referenced from another module. External entry points can referenced by declaring them with the REF pseudo instruction and are treated as relocatable values. To link to entry points with different names, a symbol can be ALIASed to another symbol. ### 2.4.2 SYMBOL ATTRIBUTES In addition to the value or byte address associated with a symbol, each symbol has symbol attributes. Symbol attributes are CYBER 180 II Assembler ERS Rev: F 2.0 LANGUAGE STRUCTURE 2.4.2 SYMBOL ATTRIBUTES ----- various pieces of information about the symbol which describe properties of that symbol. Attributes are normally associated with a symbol at the time the symbol is defined. This is an automatic process within the Assembler and takes place whenever symbol definition takes place. The CYBER 180 Assembler contains six built-in attributes which are associated with a symbol. These attributes and their associated mnemonics are: Symbol Category SC: Address Mode AM: Symbol Value VA: Length LB:, LC:, LW: Starting Bit Position S8: Symbol Number SN: Each attribute is discussed and defined in the section on Attribute Functions. A symbol's attributes are always referenced using one of the attribute function mnemonics listed above. This reference may not be forward. It is used for retrieval only, and has the form: # attribute\_function(symbol) The Assembler also permits any symbol to have any number of additional programmer defined attributes. These additional attributes can be given names and values by the programmer and can have any meaning desired. The values may not exceed 64 bits. The names and values can be altered during the course of the program assembly using the ANAME and ATRIB pseudo instructions. The ANAME pseudo instruction is used to assign a name to a particular attribute. Following that, a symbol can then be assigned a value associated with the named attribute. This attribute name may then be used in the following manner to retrieve the value of the attribute: ### user\_defined\_attribute\_name[symbol] An attribute name for any of the programmer defined attributes will be valid until changed. ### CYBER 180 II Assembler ERS CIDEN TOU IT ASSEMBLED EN 2.0 LANGUAGE STRUCTURE 2.5 REGISTERS ### 2.5 REGISIERS Register designators symbolically represent the 32 operating registers. The designators are inherent to the Assembler and cannot be changed during assembly. However, other symbols may be equated to them. There is an Assembler defined attribute (#regtyp) which defines the type of register a symbol represents. | Register_Type | Designator | |---------------|-------------------------------------------------------------| | Address | *An* or a symbol with its #REGTYP attribute set to "#AREG". | | Operand | *Xn* or a symbol with its #REGTYP attribute set to "#XREG". | For the forms An or Xn, n is a single hex digit from 0 to F. Any other value for n, for example H, causes An or Xn to be interpreted as a symbol rather than a register designator. #### **EXAMPLES:** Al Designates address register 1 All Interpreted as a symbol, not a register # 2.6 DAIA\_NOIATION Data notation provides a means of entering values for calculation, increment counts, operand values, line counts, control counter values, text for printing out messages, characters for forming symbols, etc. The two types of data notation are character and numeric. The Assembler allows the user to introduce data in the program in two basic ways. As a self defining term As a number in numeric data notation # 2.6.1 SELF DEFINING TERMS A Self-Defining Term is a constant whose value is defined by its structure. The value of a Self-Defining Term is constant throughout the program and is not altered by the relative CYBER 180 II Assembler ERS 2.0 LANGUAGE STRUCTURE 2.6.1 SELF DEFINING TERMS position of the program in storage. The Assembler uses two methods by which a Self-Defining Term can be expressed: a) As an unsigned string of binary, octal, decimal, or hexadecimal characters, the first character of which must be a decimal digit, which has the following format: numeric\_character\_string(base) Base is optional, but when present it must be enclosed by parenthesis. Base may only be hexadecimal (16), decimal (10), octal (8), or binary (2). Any other value for base results in an error. The following examples illustrate the numeric notation: ALPHA+OFF(16) "OFF(16)" is a Self-Defining Term 3\*(NET\_PAY) "3" is a Self-Defining Term The range of this form of Self-Defining Term must be consistent with its use in the program. b) As a Generalized Self-Defining Term which has the following structure symbol character-string where the character string is always enclosed by apostrophes and where "symbol" is one of the characters: # Symbol Iype\_of\_Generalized\_Self=Defining\_Term CHARACTER STRING: Constant translated into 8 bit ASCII code. The characters can be any of the characters in the Assembler character set.\* Note that a lower case letter will generate a different 8 bit ASCII code than an upper case character. The maximum string length is limited to one line and therefor cannot exceed 87 characters. Self-defining terms can assume a range of values (e.g. precision or storage occupied) depending on their type and usage. In all cases however, the internal representation of a self-defining term is an integral number of bytes. When translation from input format to internal representation occurs, self-defining terms are expanded to the next nearest multiple of bytes, provided they do not exceed the maximum defined below. <sup>\*</sup>Two consecutive quote marks in a C character string are used to indicate a single quote within the string. Rev: F 2.0 LANGUAGE STRUCTURE 2.6.1 SELF DEFINING TERMS During the expansion process, justification and filling (where required) also take place as defined: | + | Type of Self-Defining | Minimum<br> Size | Ĭ. | cimum<br>ize | + | ·+<br> <br> | | |---|-----------------------|-------------------|-------|--------------|---------------|-------------|--------| | 1 | Term | (Bytes) | 1 (8 | ytes) | Justification | 1 F | illing | | + | Decimal | 8 | | 8 | Right | 1 | Zero | | 1 | Hexadecimal | 1 1 | 1 | 8 | l Right | 1 | Zero | | 1 | Octal | 1 | 1 | 8 | l Right | 1 | Zero | | 1 | 8inary | 1 | 1 | 8 | l Right | 1 | Zero | | 1 | c , | 1 | las ! | needed | | 1 | Space | A self-defining term used as a single term expression can assume any of the values described above. When self-defining terms are used as part of a multi-term expression however, the following additional restrictions apply: - a) When an address symbol is used only the byte offset for the address is used. Bit offset, if any, and section ordinal are discarded. - b) The size of all numeric terms (decimal, hexadecimal, octal, binary, or string will be 8 bytes when arithmetic operations are performed. Strings are right justified and truncated or zero filled as necessary to be 8 bytes and are treated as integer. When an expression contains operators, the result is integer. Arithmetic operations are performed using 2's complement arithmetic. When the expression contains only one term, the result is that term (which is not converted in form). # 2.6.2 NUMERIC DATA NOTATION Numeric data can be specified in binary, octal, hexadecimal, or decimal notation with the INT and DINT pseudo instructions. Only decimal notation is available with the FLOAT and DFLOAT pseudo instructions. The value is converted to an integer or a floating point number in single or double precision. Floating point conversion is performed by a CYBER 180 math library conversion program. The actual representation of the output data is beyond the scope of this document. CYBER 180 II Assembler ERS Rev: F EK2 2.0 LANGUAGE STRUCTURE 2.6.2 NUMERIC DATA NOTATION Formats: Data\_Item \_\_\_\_\_\_ | sign | value | modifier | sign Optional. + or omitted The value is positive. The negative value is formed. value A series of binary, octal, hex or decimal digits consisting of an integer (required), optional decimal point and optional fraction, or optional An integer value (fixed point) does not contain a point, but may contain an optional base indicator enclosed in parenthesis. The fixed point format is thus a numeric, self-defining term with a sign preceding. A floating point value is noted by the occurrence of the point. If point occurs then base may not occur and value is decimal. An octal value can be a maximum of 22 octal digits and cannot exceed 64 bits of significant data. decimal value cannot exceed 5.2 x 10\*\*1232 in absolute value. used in a floating point pseudo instruction. Extra significant digits cause a diagnostic. A hex value can be a maximum of 16 digits. If value is omitted, it is assumed to be maximum The actual minimum or permitted are further limited by the pseudo instruction in which the data notation appears. modifier Associated with the value is an optional exponent modifier. Exponent defines a power of 10 scale factor. Format is E, En, E+n, or E-n. When the sign is plus or omitted, the exponent (n) is positive. When n is omitted, it is assumed to be 0. The value of n cannot exceed 32767 and is always a decimal integer. A fixed point value can have 32-bits or 64-bits of precision and a floating point value can CYBER 180 II Assembler ERS Rev: F 2.0 LANGUAGE STRUCTURE 2.6.2 NUMERIC DATA NOTATION generated in either single precision (one word) or double precision (two words), depending on the pseudo instruction. The effect of the exponent is to multiply the value by 10 decimal raised to the n power or -n power. Limitations of maximum and minimum values and exponents may be found in the appropriate CYBER 180 math library documents. Examples: Legal Illegal Explanation -21904 316E missing base 3.14159 7F(16)E-3 value must be decimal 1.7E-6 .2893 interpreted as comments. ### 2.7 EXPRESSIONS Entries in sub-fields of most source statements are interpreted as expressions consisting of a combinartion of one or more terms. A comma or blank terminates the expression. When symbolic names appear as terms in expressions the Assembler must be able to replace the symbolic name with its associated value. The association of a symbolic name with a value is called symbol definition and is described in Section 2.4. An expression in which all the symbolic names can be evaluated (which means the expression can be reduced to a single value) is said to be an "evaluable expression". An "absolute evaluable expression" is an expression whose symbolic name terms are all defined in statements previous to the current statement. ### 2.7.1 TERMS A term represents an evaluation made during the assembly process. A value is assigned to a term either by the Assembler or the term may be self-defining (as in the case of a constant). ### A term can be a: Symbol that is evaluable (One that Assembler can associate with a value) Self-defining term Function reference Attributes CYBER 180 II Assembler ERS Rev: F 2.0 LANGUAGE STRUCTURE 2.7.1 TERMS # Register designator #### 2.7.2 ORDER OF EVALUATION Expression evaluation normally is determined by the binding strength of the operators involved. This can be altered by the use of parenthesis. Terms inside of parenthesis are evaluated first. Parenthesis can be nested to any depth, and will be evaluated in the order of innermost to outermost. An expression such as INDEX+4 or AD\*(9+PAN), is reduced to a single value as follows: - a) The expression takes on the attributes of the first term in the expression from left to right. - b) Each term is given its defined value. When arithmetic operations are performed on a term it's internal representation is converted to integer. When strings are used as arithmetic terms they are truncated, if necessary, or right justified with zero fill, if necessary, to occupy 8 bytes and are treated as an integer. - c) Arithmetic operations are performed from left to right. Operations at the same parenthetical level within the highest binding strength are performed first. For example: # VE+VX\*AE/AX is evaluated as VE+((VX\*AE)/AX). d) Division always yields a truncated integer result and division by zero yields a zero result with a generated diagnostic. The operators processed by the Assembler during expression evaluation are: # CYBER 180 II Assembler ERS 2.0 LANGUAGE STRUCTURE 2.7.2 ORDER OF EVALUATION | Operators | Binding_Strength | Eunction | |--------------|------------------|-----------------------------------| | <b>★</b> | 7 | Plus (unary) | | Assi | 7 | Minus (unary) | | <b>/</b> | 7 | Logical NOT or Complement (unary) | | ** | 6 | Binary Shift (logical) | | * | 5 | Integer Multiply | | / | 5 | Integer Divide | | + | 4 | Integer Add | | - | 4 | Integer Subtract | | < | 3 | Less Than | | > | 3 | Greater Than | | <b>&lt;=</b> | 3 | Less Than or Equal | | >= | 3 | Greater Than or Equal | | = | 3 | Equal | | /= | 3 | Not Equal | | 3 | 2 | Logical AND | | 1 | 1 | Logical DR | | | 1 | Logical Exclusive OR | NOTE: All operators are binary (i.e., require two operands) except the three specifically indicated as unary. These require only one operand. # 2.7.3 THE LOGICAL NOT OPERATOR The logical NOT or complement operator causes a one's complement of its operand, based on a length of 64 bits. Yalue Binary\_Equivalent One's\_Complement ### CYBER 180 II Assembler ERS Rev: F # 2.0 LANGUAGE STRUCTURE # 2.7.3 THE LOGICAL NOT OPERATOR | 5 | 0000101 | 1111010 | |----|---------|---------| | 12 | 0001100 | 1110011 | # 2.7.4 LOGICAL AND, OR, EXCLUSIVE OR The logical AND, OR, and exclusive OR compare two operands "A" and "B" as follows: | 1 | A | • | 8 | 1 | 3 | 1 | 1 | 1 | 11 | 1 | |---|------------------|---|------------------|---|------------------|-----------|------------------|---|------------------|---| | | 1<br>1<br>0<br>0 | | 1<br>0<br>1<br>0 | | 1<br>0<br>0<br>0 | 1 1 1 1 1 | 1<br>1<br>1<br>0 | | 0<br>1<br>1<br>0 | | # 2.7.5 THE BINARY SHIFT OPERATOR The Binary Logical Shift Operator determines the direction of shift based on the sign of the second operand: a negative operand denotes a right shift and a positive operand denotes a left shift. For example: 7\*\*(-2) results in a logical right shift of two bit positions for the operand 7. Shifts are end-off with zero bit replacement. ### 2.7.6 THE COMPARISON OPERATORS The result of any comparison produced by the comparison operators is: False = 0; True = 1. # **EXAMPLES:** | Expression | Yalue | | |------------|-------|---------------------------------------------------------------------------------| | 9>11 | 0 | (9 is not greater than 11) | | /3=4 | O | (the word-size value /3 is equal to 111100 and is not equal to 4; i.e., 000100) | | 3/=4 | 1 | (3 is not equal to 4) | CYBER 180 II Assembler ERS Rev: F 2.0 LANGUAGE STRUCTURE 2.7.6 THE COMPARISON OPERATORS /(3=4) 11...11 (3 is not equal to 4, so the result of the comparison is 0 which NOTed becomes a word size value of all 1's.) ### 2.8 ABSOLUIE\_AND\_RELOCATABLE\_IERMS\_AND\_EXPRESSIONS Any term in an expression may be relocatable or absolute (non-relocatable). A relocatable term is one which represents the location of some piece of assembled code (i.e. represents an address in the memory of the computer). Its symbol category would be 6. An example would be the label of a BSS statement. An absolute expression consists of either an absolute term or a combination of terms that, when evaluated, has no relocation. An absolute term is an absolute symbol or a constant. All operators may be used with absolute terms. Absolute terms are always internally represented in the 2's complement number system (the number -0 does not exist in this system). When the Assembler is generating object data for an IOU module the data is then converted to the 1's complement number system at the time the data is output. A relocatable expression consists of a single relocatable term or a number of terms that, when evaluated, has relocation. A relocatable term results when an absolute term is added to or subtracted from a relocatable term and the result is not negative and does not exceed the storage capacity of a section. All arithmetic operations may be performed on relocatable terms. If a relocatable term cannot result, then the relocatable term is first converted to an absolute term whose value is the byte offset of the relocatable term and the result of the arithmetic operation is an absolute term. If an absolute value is required of an expression, then it is converted to absolute value. A relocatable value is required only for certain operands of the ADDRESS pseudo instruction. If an expression contains only a single term, the result is that term and the result may be absolute, relocatable, or string. CYBER 180 II Assembler ERS Rev: F 3.0 PROGRAM STRUCTURE ### 3.0 PROGRAM\_SIRUCIURE This chapter describes the general structure of a program. In some cases, it repeats information described elsewhere and correlates it so that the programmer will obtain a better understanding of how the program is assembled, loaded, and executed. Some references are made to the NOS/VE Loader but for a complete description of the loader, refer to the applicable NOS/VE document. A CYBER 180 program consists of one or more modules that can be assembled separately, either in the same computer run or in independent runs. The Assembler will assemble many modules from the same input file per call. These many program modules can all be written in the Assembler source language, or can be written in any other source language available in the product set of the operating system as long as the compiler or Assembler produces relocatable binary output in a form acceptable to the NOS/VE loader. An Assembly language module is composed of statements beginning with an IDENT pseudo instruction and ending with an END pseudo instruction. The Assembler repertoire includes pseudo instructions that facilitate relocatable module linkage. Through these linkages, modules loaded together can transfer control to each other and can access common storage locations. The first topic considered in this chapter is the program module and how the Assembler and the programmer organize the object code into program sections. Following this is a brief description of the counters that control the sections. ### 3.1 PROGRAM\_SECTIONS A CYBER 180 Assembly program is a collection of statements which are translated via an assembly process, into a CYBER 180 object module. Object modules resulting from separate assemblies, or compilations by a CYBER 180 Compiler (CYBIL, FORTRAN, etc.) can be combined, via a linking process, into a single object module, and may undergo further transformation into a form capable of direct execution by the CYBER 180 hardware. A set of statements between an IDENT pseudo instruction and an END pseudo instruction is a program module. A CPU program module can be divided into sections having different attributes. For instance, the CDDE section has the attributes of READ and CYBER 180 II Assembler ERS Rev: F 3.0 PROGRAM STRUCTURE 3.1 PROGRAM SECTIONS DIT INDUMAN JEGITONS EXECUTE, while the WORKING section is READ and WRITE. The use of sections provides a means of code protection. As assembly of a program module proceeds, the Assembler or the user designates that object code be generated or that storage be reserved in specific sections. By properly assigning code sequences, data, or reserved storage areas in blocks through use of DRG or USE, a programmer can intermix instructions and data for the different sections. The Assembler assigns locations in a section consecutively as it encounters instructions destined for the section. A symbol defined within a section is not local to the section. That is, it is global and can be referred to from any other section in the program. For the CPU there are several types of sections available, but for the IOU only one section is permitted. Only a CPU module may contain SECTION or USE statements. If a CPU module does not contain a USE instruction or if object code is generated (or storage reserved) before the first USE instruction, the Assembler places the object code in the CODE section, which is one of the five default sections. The user controls use of the default-sections and any user-established sections, through USE, ORG, and SECTION pseudo instructions. ### 3.1.1 DEFAULT SECTIONS The following is a list of default sections and their attributes established for the user by the Assembler: CPU SECTIONS: CODE READ+EXECUTE WORKING READ+WRITE BINDING\* BIND+READ STACK\* READ+WRITE IOU SECTIONS: CODE READ+WRITE+EXECUTE Symbols may be associated with addresses in these sections, but data may not be initialized at assembly time except for the BINDING section in which pointers may be established through the use of the ADDRESS pseudo instruction. # 3.1.2 THE BINDING SECTION The BINDING section is a special purpose section whose function is to permit access to data and code that is either internal or external to the current module. This is accomplished CYBER 180 II Assembler ERS Rev: F 3.0 PROGRAM STRUCTURE 3.1.2 THE BINDING SECTION > via pointers in the BINDING section which are built by the NOS/VE loader. In addition, the NOS/VE Library\_Generator may "bind" modules together. Part of this "binding" process consists of consolidating the separate BINDING section of each module into one common BINDING section by eliminating redundant entries (pointers) in the BINDING section. This means that "binding" inherently requires that entries in the BINDING section be Morder The user must beware to preserve this "order independence". > It is recommended that reference to the pointers in the BINDING section be limited to the "load" type instructions (See Section 7.3.1) or the CALLSEG instruction. For instructions the Assembler inherently generates "relocation" object text which permits the Library\_Generator to adjust the displacement field of these instructions to a new value as a result of module "binding". > The use of other CPU instructions (e.g. ADDRQ) or generation of data which contains a displacement relative to the BINDING section: is permitted and the Assembler will generate necessary "relocation" object text with the assumption that the field (displacement) being generated is an unsigned positive If this assumption is not correct, the relocation attributes may be specified by the intrinsic Relocation\_function (R:) (See Section 5.1.9). If the relocation attributes cannot be specified by the relocation function: (R:), then the module cannot be bound and if the module is to be assembled without diagnostics the module must be declared "NONBINDABLE" via the MACHINE statement (See Section 4.2.1). ### 3.2 SECIION\_CONTROL\_COUNTER Each section has a section counter from which the byte offset from the beginning of the section, and the bit offset in the current byte can be obtained. The Assembler automatically updates and maintains this counter when a section is first established, or its use is resumed. The current contents of the location counter may be returned as a relocatable value via the location counter function \$ (dollar sign). The byte offset is the relative location of the next byte to be assembled or reserved in the section. It is possible to increment the byte offset simply by using either ORG or BSS pseudo instructions. ORG also permits the programmer to reset the counter to some lower location in the section. The current byte offset can be referenced by using the function \$(0). # CYBER 180 II Assembler ERS 3.0 PROGRAM STRUCTURE 3.2 SECTION CONTROL COUNTER The bit offset points to the next bit to be used in the current byte, and can range in value from 0 to 7 for a CPU module and 0 to 15 for an IOU module. It can be referenced by using the function \$(1). # 3.2.1 FORCING PARCEL ALIGNMENT A parcel is the minimum instruction size of either the CPU or IOU. For both the CPU and IOU a parcel is 2 bytes or 16 bits. The CYBER 180 hardware requires that all instructions start on a parcel boundary. For the CPU this also means that the byte address of the instruction must be even. In a CYBER 180 Virtual Machine assembly, if any of the following conditions are true, the Assembler forces parcel alignment. - Insufficient room remains in a partially filled parcel for the next instruction to be generated. - The current statement is an END, IDENT, or ALIGN 0,2 pseudo instruction. # CYBER 180 II Assembler ERS 4.0 PSEUDO INSTRUCTIONS ### 4.0 PSEUDO\_INSTRUCTIONS Pseudo instructions are instructions needed by the programmer to write programs, but for which there are no hardware equivalents. Pseudo instructions discussed in this chapter are classified according to application as follows: Module identification (IDENT and END) Binary control (MACHINE) Symbol assignment (EQU, SET, ANAME, ATRIB) Module linkage (DEF, DEFG, REF, ALIAS and ADDRESS) Data generation (BSSZ, INT, DINT, FLOAT, DFLOAT, PDEC, CMD, VFD and TRUNC) Assembly control (DO, ELSE, DEND, WHILE, and SKIPTO) Error control (ERROR, FLAG) Listing control (LIST, PAGE, SPACE, TITLE, XRSY) Section control (SECTION, USE, DRG, POS, BSS, ALIGN) Procedure/function pseudo instructions (PROC, PEND, PNAME, FNAME LOCAL, OPEN, CLOSE, CONT) In general, pseudo instructions can be placed anywhere in a module. The following list of pseudo instructions is valid only for a CPU module. The presence of any of these instructions in an IDU module will generate and error. ADDRESS ALIAS DEF DEFG DFLOAT DINT FLOAT INFOMSG PDEC REF SECTION USE ### 4.1 MODULE\_IDENIIEICATION Module identification pseudo instructions designate the beginning and end (IDENT-END) of a module). #### CYBER 180 II Assembler ERS 4.0 PSEUDO INSTRUCTIONS 4.1.1 IDENT - MODULE IDENTIFICATION 4.1.1 IDENT - MODULE IDENTIFICATION An IDENT pseudo instruction of the following form is the first statement of a module recognized by the Assembler. input statement must be an IDENT or comment statement and if end information does not follow an END statement then the statement following END must be another IDENT or Only an IOU module assembly permits several IDENT statement. statements before the END statement, where each IDENT identifies an IOU overlay. Assembler flags any spurious use of IDENT before END as an error. For an IOU module only, the IDENT statement permits 3 operands. For a CPU module the argument field must be blank. > loperation largument \_\_\_\_\_\_ IDENT lentry.origin.iouno Name of the module, it is required and can be 1-31 name characters of which the first must be alphabetic as defined in Section 2.3. This name cannot redefined, and may be used to reference the code section. (required for an IOU module) A symbol specifying the entry IOU overlay entry address. Symbol category must be (required for an IOU module) An expression specifying origin the first word address of the IDU overlay. represent a valid IOU memory address (0-0FFF(16)) else an error is diagnosed. (optional) Absolute expression specifying the number iouno of the IDU on which the program is to be loaded. Example: .TEST is the name of the module TEST IDENT 4.1.2 END - END MODULE An END pseudo instruction must be the last statement of each It causes the Assembler to terminate all counters. conditional assembly, procedure generation and code duplication. CYBER 180 II Assembler ERS 5 Rev: F 4.0 PSEUDO INSTRUCTIONS 4.1.2 END - END MODULE The Assembler combines all local blocks (sections) into a relocatable subprogram block, generates the relocatable binary tables and produces the listing. > +----llabel | loperation | argument IEND llabel Itralabel label Optional, last address of the module. tralabel Optional, a 1-31 character symbol specifying the entry point to which control transfers for a CPU module. Tralabel is invalid in an IOU module and must be omitted. This symbol must be declared as an entry point in the (linked) CPU module, either by a DEF, DEFG, or REF pseudo instruction in this module. At least one module must specify a transfer address or the loader signals an error. If more than one module indicates a transfer address, then the loader uses the first one encountered. Example: START .START is the transfer label END #### 4.2 BINARY\_CONTROL This section describes a pseudo instruction that allows the user to control the binary output produced by the Assembler. #### 4.2.1 MACHINE - DECLARE OBJECT PROCESSOR TYPE The MACHINE pseudo instruction specifies the type of computer processor on which the object program can be executed. A MACHINE statement must appear before any generated code. The MACHINE pseudo instruction also identifies which instruction mnemonics are permitted (CPU or IOU) and which type of object text to generate (CPU or IOU). No more than one MACHINE pseudo instruction may appear within any assembly unit (IDENT-END). | 4 | | + | | |---|-------|------------|---| | 1 | label | loperation | • | | 1 | | MACHINE | • | C180CPU The object processor is a CYBER 180 CPU type CYBER 180 II Assembler ERS Rev: F 4.0 PSEUDO INSTRUCTIONS 4.2.1 MACHINE - DECLARE OBJECT PROCESSOR TYPE (default). The Assembler will accept CPU (default). The Assembler will accept CPU instruction mnemonics and will generate CPU object text. C180IOU The object processor is a CYBER 180 IOU. The Assembler will accept IOU instruction mnemonics and will generate IOU object text. Negative numbers in the generated data will be in 1's complement form (since the IOU is a 1's complement processor). No other type is available at this time. bind This subfield is applicable only if type is C180CPU. BINDABLE (DEFAULT) The Assembler will generate additional object text to permit the Library\_generator to "bind" the module. If the other statements in the module do not conform to the rules for "bindable" code then a FATAL diagnostic will be issued for each of these statements (See Section 5.1.9). NONBINDABLE The object text generated will have the "non-bindable" attribute set. No diagnostics will occur if the rules for "bindable" code are not followed. The Library\_generator will abort if an attempt is made to "bind" this module. Example: MACHINE C180CPU .Binary is for a CYBER 180 CPU # 4.3 SYMBOL\_ASSIGNMENI The pseudo instructions SET and EQU permit direct assignment of values to symbols. The values can be absolute or relocatable. Subsequent use of the symbol in an expression produces the same result as if the value had been used as a constant. Symbols defined using EQU cannot be redefined. Any symbol may be given one or more programmer defined attributes by using the ANAME pseudo instruction to define an attribute name, and then using the ATRIB pseudo instruction which assigns a specific value to a specific symbol. Once defined, the attribute function may be used to recover the attribute value assigned to the argument. CYBER 180 II Assembler ERS Rev: F 4.0 PSEUDO INSTRUCTIONS 4.3.1 SET/EQU - ASSIGNMENT OF VALUES: ### 4.3.1 SET/EQU - ASSIGNMENT OF VALUES A SET or EQU pseudo instruction defines the symbol in the field as having the value and attributes indicated by the expressions in the argument field. The difference between SET and EQU is that symbols defined with an EQU cannot be redefined, whereas symbols defined with a SET may be redefined with a subsequent SET any number of times. | + | + | + | |-------|------------|-----------| | · | loperation | largument | | label | ISET | llist | | label | IEQU | llist | label (Required) A list of one or more symbols, or symbol element number identifiers to which the argument field list is assigned. It will have a symbol category of 9. list Evaluatable expressions. The expressions include symbols as yet undefined. The maximum value element list cannot exceed (OFFFFFFFFFFFFFF(16)). When the first element in the list is a symbol, the attributes of that symbol will replace the attributes of the symbol in the label field. Any symbol in the label field cannot be referred to prior to its first definition. The SET and EQU pseudo instructions assign a list of values to the symbol(s) in the label field. The list must contain only evaluable expressions at the time the pseudo instruction is processed by the Assembler. The label field may consist of list names (symbols) or list element identifiers. List elements are referenced using the form: ### listname[element number] where listname is the name of the list, and element number is an evaluable expression denoting a particular element in the list, where, for an n element list, element number = 0, 1, 2, ..., n-1. A negative element number is diagnosed as an error. A SET or EQU pseudo instruction within a PROCEDURE processed by the Assembler only when the PROCEDURE is referenced CYBER 180 II Assembler ERS Rev: F 4.0 PSEUDO INSTRUCTIONS 4.3.1 SET/EQU - ASSIGNMENT OF VALUES and not when the PROCEDURE is defined. The expressions which comprise the list elements must be evaluable therefore, only when the PROCEDURE is referenced. A particular list element may have a value of ZERO or NULL depending on how that element is defined. A null element is assigned to a list whenever a position for a list element is indicated with appropriate commas, but the position is devoid of contents. A null list element has the numeric value zero when used computationally. Null elements may be transferred from one list to another. The argument field is completely processed and for each subfield in the argument list the value is assigned to the corresponding value element of each of the symbolic names in the label field. If a list is specified, it is replaced completely by the argument. If a list element is specified, replacement is on an element by element basis. The designated element is replaced by the first argument list value, and succeeding elements being replaced by the corresponding argument value. # Example\_#1 SET 3,5,7,12,15 When this pseudo instruction is processed by the Assembler, the label "A" is associated with the list 3,5,7,12,15. The elements and their values are: > A[0] = 3A[1] = 5 A[2] = 7 A[3] = 12 A[4] = 15 $A[5] = 0 \cdot (Null)$ Following the previous pseudo instruction, we could then give the pseudo instructions: > A[1] SET 42 17 A[4] SET A[5] SET 8 And the list associated with "A" would then be: A[0] = 3 A[1] = 42 A[2] = 7 A[3] = 12 ### CYBER 180 II Assembler ERS ### 4.0 PSEUDO INSTRUCTIONS # 4.3.1 SET/EQU - ASSIGNMENT OF VALUES \_\_\_\_\_\_ A[4] = 17 A[5] = 8 $A[6] = 0 \cdot (Null)$ ## Example\_#2 In this case, the symbol SUM must have been previously defined. If its value were 50, then the Assembler would establish two lists X and Y which would both be associated with the list: 53,12,57,6 In addition, any previous list associated with either X or Y would be erased. The following instructions may then be given: Z SET X X[0] SET SUM+1 ZZ SET X X SET 5.3.1 After these pseudo instructions have been executed, the lists appear as: X = 5,3,1 Y = 53, 12, 57, 6 Z = 53,12,57,6 ZZ = 51.12.57.6 # Example\_#3 BIND\_REG EQU A3 .points to the binding segment TEMP\_REG SET A5 .temporary working register BIND\_REG now is equal to 3 and has the attributes of #AREG. The symbol BIND\_REG cannot be redefined. TEMP\_REG is equal to A5 and has the attributes of #AREG. TEMP\_REG can be changed with a subsequent SET. ### Example\_#4 A SET 0,1,2,3,4 A[2] SET 5,6 results in the list: A = 0.1.5.6.4 CYBER 180 II Assembler ERS Rev: F CIDEN 100 11 M22CHD1C1 FU2 4.0 PSEUDO INSTRUCTIONS 4.3.1 SET/EQU - ASSIGNMENT OF VALUES The pseudo instruction: ne pseudo instruction. A[1] SET .. 10.. 11 modifies the list to: A = 0...10..11 4.3.2 ANAME DIRECTIVE The ANAME pseudo instruction is used to define a programmer defined attribute name and to assign a particular attribute number to that name. A particular attribute number may have several names associated with it by using ANAME more than once. | label | loperation | argument | label | IANAME | Ivalue label A previously undefined symbol. value Evaluatable expression whose value can be any positive integer. 4.3.3 ATRIB DIRECTIVE The purpose of the ATRIB pseudo instruction is to assign a value to the programmer defined attribute of a particular symbol. The symbol to which the attribute value is assigned is the symbol in the LABEL field. If the symbol in the LABEL field of this pseudo instruction is not previously defined, it will be placed in the permanent symbol table and given a symbol category of 1, and the specified attribute assigned to it. If the symbol in the LABEL field has been previously defined, the value is assigned to the attribute of the symbol and replaces any previous value assigned to that symbol for that attribute. Normally, a symbol must be defined before attribute values are assigned to that symbol. An exception occurs when PROCEDURES are executed while a source statement is being processed. | label | operation | argument | label | ATRIB | attribute, value CYBER 180 II Assembler ERS 4.0 PSEUDO INSTRUCTIONS 4.3.3 ATRIB DIRECTIVE label A label field symbol is required. attribute A previously defined (using the ANAME pseudo instruction) programmer defined attribute name. value Evaluatable expression. 4.3.4 USE OF THE ANAME AND ATRIB PSEUDO INSTRUCTIONS CONSIDER THE FOLLOWING SEQUENCE OF DIRECTIVES: INDEX ANAME 1 BASE ANAME 2 - At this point we have defined two programmer defined - attributes INDEX and BASE. Any symbol can now have values - assigned to these attributes. SMB1 ATRIB INDEX.5 SMB1 ATRIB BASE, OA(16) - At this point, the INDEX attribute of SM81 is 5 - and the BASE attribute of SM81 is a hexadecimal A. SMB1 ATRIB INDEX.0 SMB1 ATRIB BASE, 2 - At this point the INDEX and BASE attributes of SMB1 have been - reassigned to the values: - INDEX[SMB1] = 0 - BASE[SMB1] = 2 - Attributes may be used as terms of an expression. BASE[SMB1] JA SET JB EQU INDEX[SMB1] 4.4 MODULE\_LINKAGE The pseudo instructions DEF, DEFG, and REF are valid only in CPU modules, and are used to denote entry points, either in the current module or a separately assembled/compiled module. A symbol flagged as an entry point denotes an address representing data or code, which can be referenced by other modules. through the use of entry points that the NOS/VE loader is able to ### CYBER 180 II Assembler ERS 4.0 PSEUDO INSTRUCTIONS 4.4 MODULE LINKAGE link modules together. See the appropriate NOS/VE loader document for complete details. 4.4.1 DEF, DEFG-DECLARE ENTRY SYMBOLS The DEF and DEFG pseudo instructions define symbols as entry points in the current CPU module. DEFG pseudo instruction defines symbols as gated entry points. (Gated entry points are explained further in the NOS/VE loader documentation.) | label | operation | argument | |-------|-----------|--------------------------------------| | • | DEF | sym1,sym2,,symn<br> sym1,sym2,,symn | symi (Required) Linkage symbol from 1-31 characters of which the first must be alphabetic as defined in section 2.4. (Also see ALIAS statement.) Each symbol must be further defined in the module as a relocatable address (catagory 6). The symbol may not be a LOCAL or OPENED symbol. The appearance of the same symbol more than once in a DEF or DEFG is not an error, but the symbol may not appear in both a DEF and DEFG statement. # Example: DEF PRG1 .PRG1 is a symbol in this compilation unit. 4.4.2 REF-DECLARE EXTERNAL SYMBOLS The REF pseudo instruction lists symbols that are defined as entry points in independently compiled or assembled CPU modules for which references can appear in the module being assembled. | llabel | loperation | argument | |--------|------------|----------------| | | • | sym1.sym2,symn | symi (Required) Linkage symbol, 1-31 characters of which the first must be alphabetic as defined in Section 2.4. These symbols must not be further defined within the module being assembled. Note that it is still possible to have new definitions for the symbol by using LOCAL or OPEN statements. (Also see ALIAS CYBER 180 II Assembler ERS Rev: F 4.0 PSEUDO INSTRUCTIONS 4.4.2 REF-DECLARE EXTERNAL SYMBOLS statement.) Symbols may be declared in a REF statement prior to or subsequent to their use in the program. They must be global symbols, and cannot have been declared OPEN or LOCAL. Symbols which are declared in a REF pseudo instruction are assumed to be relocatable and their use in expressions must follow the rules for relocatability. Any further definition of a REF symbol will be diagnosed as an error. # Example: REF TAGX .TAGX IS AN ENTRY POINT IN A DIFFERENT .ASSEMBLY/COMPILATION UNIT. 4.4.3 ALIAS - EQUATE LINKAGE SYMBOLS The ALIAS pseudo instruction gives the programmer the ability to declare entry points with names other that that used within the current CPU module. | + | + | | |---|------------|-----------| | | loperation | largument | | - | ALIAS | | namel 1-31 character linkage symbol used by the Assembler. This symbol must be further defined in the module as a DEF, DEFG, or REF symbol. name2 1-31 character CYBER 180 linkage symbol. This symbol is not restricted by the limits of symbol definition in Section 2.4. The symbol must consist of alphabetic or numeric characters, the first of which must be alphabetic. The colon may not be used as one of the characters. ### Example: TAG ALIAS TAGFORALONGNAME .TAG FOR A LONG NAME IS .DEFINED IN A DIFFERENT .COMPILATION UNIT. 4.4.4 ADDRESS - FORM CYBER 180 ADDRESS The ADDRESS pseudo instruction enables the generation of CYBER 180 II Assembler ERS. Rev: F 4.0 PSEUDO INSTRUCTIONS 4.4.4 ADDRESS - FORM CYBER 180 ADDRESS references to full Process Virtual Address (PVA's) in a CPU module, to be filled in by the NOS/VE Loader. Generally, this pseudo instruction is used in the BINDING section to form pointers. | + | + | | |---|------------|----------------------| | | loperation | argument | | - | • | typ1,sym1,,typn,symn | label Optional, symbol assigned the value of the beginning of the address list. Symbol category equals 6. typi Type designating the address insertion type. It can have only the following values else an error is diagnosed: - P (Pointer) Creates a pointer (PVA) to the specified address. The generated object code is one word long and is word aligned relative to the section origin. The PVA is stored in the generated object code right justified with zero fill. - C (Code Base Pointer) Used for linking procedures. The format for the PVA is one word of generated object code for internal symbols, and two words of generated object code for external symbols. The generated object code is always word aligned relative to the section origin with the PVA being right justified with zero fill. - CI- (Code Base Pointer Internal Format) Generates object code for a code base pointer in internal format (1 word) for the symbol, without regard as to whether the symbol is internal or external. The generated object code is word aligned relative to the section origin with the PVA being right justified with zero fill. - CE- (Code Base Pointer External Format) Generates object code for a code base pointer in external format (2 words) for the symbol, without regard as to whether the symbol is internal or external. The generated object code is word aligned relative to the section origin with the PVA being right justified and zero filled. - R (Relative) Generates object code for a PVA which CYBER 180 II Assembler ERS pincu ion ii waacminici rua 4.0 PSEUDO INSTRUCTIONS 4.4.4 ADDRESS - FORM CYBER 180 ADDRESS points to a symbol with an offset. The length of the generated object code is 8 bytes in the binding section, or 6 bytes in any other section. The generated object code is word aligned relative to the section origin when in the binding section with the PVA being right justified with zero fill. When not in the binding section, the generated object code is byte aligned. symi Following each TYPI subfield there must be a single, corresponding SYMI subfield which contains a symbol or expression which identifies the internal or external location for which a PVA is to be created. Expressions are permitted only when TYPI is R. # Example: USE BINDING REF TESTDATA TAG ADDRESS C. TESTDATA USE #LASTSEC C.TESTDATA GENERATES A 2 WORD PVA FOR TESTDATA WHICH IS IN A DIFFERENT MODULE. # 4.5 DAIA\_GENERATION The instructions described in this section are the only pseudo instructions that generate data. All other program data is generated through symbolic machine instructions. ### 4.5.1 BSSZ-RESERVE ZEROED STORAGE The BSSZ pseudo instruction generates zeroed bytes of data in the section of a CPU module currently in use or it generates zeroed 16-bit words of storage in an IOU module. | + | 4 | | |---|------------|----------| | | loperation | argument | | * | 18SSZ | * | label Optional, label defined as the byte offset in the section after the appropriate alignment occurs. The symbol identifies the beginning of the reserved storage area. aexp Absolute evaluable expression specifying the number of zeroed units (bytes for CPU or words for IDU) of CYBER 180 II Assembler ERS 4.0 PSEUDO INSTRUCTIONS 4.5.1 BSSZ-RESERVE ZEROED STORAGE storage to be reserved. The expression cannot contain external symbols or result in a relocatable or negative value. A BSSZ O or an erroneous expression causes a force to a unit (byte for CPU or word for IOU) and the symbol definition, but no storage is reserved. If storage is to be reserved in a CPU module starting at a word, halfword, or parcel boundary, then the BSSZ must be preceded by one of the appropriate alignment pseudo instructions. # Example: ALIGN 0.8 .FORCE BYTE DFFSET TO A WORD BOUNDARY. TAG 10 .RESERVES 10 BYTES OF ZEROES. BSSZ 4.5.2 INT - GENERATE INTEGERS The INT pseudo instruction generates one or more 32-bit integers on a byte boundary in the current section of a CPU module for each item listed in the argument field or it generates one or more 16-bit integers on a word boundary in an IOU module for each item listed in the argument field. | + | + | <del> </del> | |--------|------------|---------------------| | | loperation | largument | | llabel | • | litem1,item2,,itemn | label Optional, symbol is assigned the byte offset in the section after the force to the appropriate boundary occurs. Symbol category equals 6. Value of the numeric data item itemi Numeric data item. cannot exceed the storage capacity of the item being generated. ### Example: 1.2.3 TAG INT 4.5.3 DINT - GENERATE 64-BIT INTEGERS The DINT pseudo instruction generates one 64-bit integer on a byte boundary in the current section of a CPU module for each item in the argument field. CYBER 180 II Assembler ERS Rev: F 4.0 PSEUDO INSTRUCTIONS 4.5.3 DINT - GENERATE 64-BIT INTEGERS | label | operation | argument | label | DINT | litem1.jtem2....jtemn label Optional, symbol assigned the byte offset in the section after the force to a byte boundary occurs. Symbol category equals 6. itemi Numeric data item. Example: TAG DINT 1,2,3 4.5.4 FLOAT - GENERATE SINGLE PRECISION FLOATING-POINT NUMBERS The FLOAT pseudo instruction generates one 64-bit floating point number on a byte boundary in the current section of a CPU module for each item listed in the argument field. Note that floating point numbers entered with a decimal point must have a digit preceding the period (else the remainder of the statement will be interpreted as comments). | + | + | <del> </del> | |---|------------|-----------------------| | - | loperation | argument | | • | • | litem1, item2,, itemn | label Optional symbol assigned the byte offset in the section after the force to a byte boundary occurs. Symbol category equals 6. itemi Numeric data item. Value of numeric data item cannot exceed the storage capacity of a single precision (64-bit) floating point item. Conversion of the numeric data item into the internal floating point representation is performed by a CYBER 180 math libray program. Consult the appropriate CYBER 180 math libray documentation for further information. Example: TAG FLOAT 1.347E-6,0,-6.3416E12,1. CYBER 180 II Assembler ERS Rev: F 4.0 PSEUDO INSTRUCTIONS 4.5.5 DFLOAT - GENERATE DOUBLE PRECISION FLOATING-POINT NUMBERS 4.5.5 DFLOAT - GENERATE DOUBLE PRECISION FLOATING-POINT NUMBERS The DFLOAT pseudo instruction generates one double precision, 128-bit floating point number on a byte boundary in the current section of a CPU module for each item listed in the argument field. Note that floating point numbers entered with a decimal point must have a digit preceding the period (else the remainder of the statement is interpreted as comments). | + | -+ | | |-----|------------|--------------------| | | loperation | argument | | • . | • | litem1,item2,itemn | label Optional symbol assigned the byte offset in the section after the force to a byte boundary occurs. Symbol category equals 6. Numeric data item. The value of the numeric data item must be within the limits of the storage capacity of the item being generated. Conversion of the item into internal floating point representation is performed by a CYBER 180 math library program. Consult the appropriate CYBER 180 math library documentation for further information. # Example: TAG DFLDAT -22.661,6.87701E-14,1E3,0.00000001762 4.5.6 PDEC - GENERATE PACKED DECIMAL DATA The PDEC pseudo instruction generates packed decimal data on a byte boundary for the length of the field desired. | + | + | · | |---|------------|-----------| | | loperation | · · · · · | | • | IPDEC | C'string' | Optional symbol assigned the byte offset in the section after the force to a byte boundary occurs. Symbol category equals 6. string Signed or unsigned numeric decimal character string CYBER 180 II Assembler ERS CIDER 100.11 ASSEMBLE CRS REV. F 4.0 PSEUDO INSTRUCTIONS 4.5.6 PDEC - GENERATE PACKED DECIMAL DATA is required. Any other argument type is diagnosed as an error. Each character in the string generates a 4-bit code. Only the characters 0-9 and + or - are permitted. Any other characters in the string are diagnosed as an error. The sign character (+ or -) must be the last (rightmost) character. If the data is to be used by a BDP instruction the user must insure that the contents of the generated object code fit the requirements of the BDP type designator (See Section 7.4). Example: TAG PDEC C'1234" 4.5.7 CMD - GENERATE BIT STRING The CMD pseudo instruction is a single statement form of PROCEDURE. The output of the CMD pseudo instruction is a string of binary bits together with appropriate control information for the CYBER 180 LBADER. The length of the binary bit string is controlled by the "length list" and the contents of the binary bit string are controlled by the "value list". Both the "length list" and the "value list" can contain multiple subfields, provided that the total bit string produced is greater than zero and less than or equal to 1024 bits. | label | loperation | largument | label | lCMD, l\_lst | lv\_lst label A label field symbol is required. It is used to define the OPERATION field name by which this particular CMD definition will be referenced in subsequent statements of the program. The CMD statement must appear prior to any reference to the operation it defines and may not appear within a PROCEDURE definition. The (optional) label appearing on a line referencing a CMD defined operation will be associated with the generated bit string. Symbol category equals 6. I\_lst The length list is a list of evaluable expressions whose value represents the length in bits, of each argument field element to be generated by the Assembler. This list is ordered from left to right. If the value of the "l\_lst" causes an overflow of 4.0 PSEUDO INSTRUCTIONS 4.5.7 CMD - GENERATE BIT STRING the section counter, then an error will be diagnosed. In one-to-one correspondence with the "length: list" $v_1$ st is a "value list", which is a list of expressions assigned to determines the <u>value</u> corresponding element of the "length list". If number of elements in "l\_lst" does not match the number of elements in "v\_lst" then an error is diagnosed. If the value of a "v\_lst" exceeds: the storage capacity allocated by the corresponding "l\_lst" element, then an error may or may not be diagnosed depending on the use of the TRUNC statement (See Section 4.5.9). Example: (Also see the section on PROCEDURES) LA CMD, 8, 4, 4, 16 84(16), F: (2, 1), F: (2, 0), F: (2, 2) 4.5.8 VFD - VARIABLE FIELD DEFINITION The VFD pseudo instruction generates a string of binary bits. The (optional) label is associated with the data string. The difference between the CMD and VFD pseudo instructions is that the CMD pseudo instruction is a template which does not generate output until called, whereas the VFD pseudo instruction generates output when it is encountered. | label | loperation | argument | label | IVFD,1\_1st | v\_1st | - label Optional symbol assigned the byte offset in the section. - 1\_1st A list of evaluable expressions which represent the length in bits of each subfield to be constructed. This list is ordered from left to right. If length list causes an overflow of the section counter then an error will be diagnosed. - v\_lst In one-to-one correspondence with the length list is a list of expressions which determine the value assigned to the elements of the length list. If the number of elements of "l\_lst" does not match the CYBER 180 II Assembler ERS Rev: F 4.0 PSEUDO INSTRUCTIONS 4.5.8 VFD - VARIABLE FIELD DEFINITION number of elements of "v\_lst" then an error is diagnosed. If the value of the "v\_lst" element exceeds the storage capacity specified by the corresponding "l\_lst" element, then an error may or may not be diagnosed depending on the use of the TRUNC statement (See Section 4.5.9). Example: LIST1 VFD,8,16,8,3\*8 1,4F(16),6,C\*ABC\* 4.5.9 TRUNC - TRUNCATE The TRUNC pseudo instruction is used to indicate what action is to be taken, if it is necessary to truncate a value in order to enable it to fit into a field specified by a CMD or VFD pseudo instruction. | + | + | <del></del> | |---|-----------|-------------| | | operation | | | * | TRUNC | value | value Value is one of the numbers 0 and 1 which have the following meaning: - O: Truncate and do not associate an error flag with the data generated. - 1: Truncate and flag the word generated as in error. An attempt will always be made to fit the significant bits of a value into a field. When type 1 truncation is specified, the elimination of an unbroken string of non-significant zeros or elimination of an unbroken string of 1's in the case of a negative number, is not considered to be an error. When character data is truncated, trailing blanks are not considered an error. More than one TRUNC pseudo instruction may appear in a program. The most recently encountered TRUNC pseudo instruction will be used. If no TRUNC pseudo instruction appears in a program, "type 0" truncation will be used. Example: TRUNC 1 .FLAG TRUNCATION ERRORS. CYBER 180 II Assembler ERS Rev: F 4.0 PSEUDO INSTRUCTIONS 4.5.10 INFOMSG #### 4.5.10 INFOMSG The INFOMSG pseudo instruction is used to control: the generation of the Informative Diagnostic issued when data generation occurs in the BINDING or STACK sections of a CPU module.\* | + | + | + | |---|-----------|----------| | · | operation | | | + | + | + | | 1 | INFOMSG | l va lue | value - LISTON Turns generation of error message on (default). - blank Suppresses generation of error message. #### Example: INFOMSG LISTON .FLAG DATA GENERATION ERRORS. - \* Data cannot be initialized in the Binding and Stack sections at assembly time, with the exception of the ADDRESS pseudo instruction which can be used in the Binding section. - 4.6 ASSEMBLY\_CONIROL - 4.6.1 DO/ELSE/DEND PSEUDO INSTRUCTIONS This group of pseudo instructions is used for conditional iterative control of Assembler processing. The format of these pseudo instructions is: | 4 | | | | |---|-------|-----------|------------| | | | operation | argument | | | label | | expression | | | label | DEND | 1 | label Optional label that is assigned the value of the expression when used on the DO statement. It is not valid on the ELSE pseudo instruction. When specified on a DEND, a cycle effect can be created by using a SKIPTO LABEL instruction. The label of a DEND statement is never entered in the Assembler's symbol table and the presence of a label field is used only 4.0 PSEUDO INSTRUCTIONS 4.6.1 DO/ELSE/DEND PSEUDO INSTRUCTIONS as the object of a SKIPTO. expression Expression must be absolute and evaluable. This expression represents the number of times the DO loop will be executed. If no expression is present, the argument of the DO will be treated as O. A boolean condition can be specified for conditional assembly of code. A DEND pseudo operation must be associated with each DO pseudo operation written. However, the ELSE need not be present, but if desired, must occur between the DO and DEND. The DO pseudo operation operates as follows: - a) An internal counter is set up and initially given the value of 0. - b) If a label is present on the DO line, its value is set to 0. - c) The expression on the DD line is evaluated. Denote the results of this calculation by $n_{\bullet}$ (If no expression was present or the expression was not evaluable, n = 0). - d) If $n \le 0$ , skip succeeding lines until an ELSE or DEND pseudo operation is encountered. - If an ELSE pseudo operation is encountered, assemble succeeding statements until a DEND line is encountered. Continue assembly at the statement after the DEND line. - 2) If a DEND pseudo operation is encountered, resume assembly at the statement following the DEND line. - e) If n > 0, the following action occurs: - 1) Increment the internal counter by 1. - 2) If a label was present on the DB line, set the value of the label equal to the new value of the internal counter. - 3) Assemble all lines until an ELSE or DENO pseudo operation is encountered. - 4) Compare the internal counter to n. - a) If the count is less than n, repeat the procedure from step (e). This causes the count to be incremented, and resumes assembly of the statements # CYBER 180 II Assembler ERS 4.0 PSEUDO INSTRUCTIONS 4.6.1 DO/ELSE/DEND PSEUDO INSTRUCTIONS following the DD. b) If the count is equal to n, terminate control of the DD pseudo operation and resume assembly at the line immediately following the DEND, skipping all statements between the ELSE and DEND if necessary. # Example: ``` EXAMPLE 1) The following code will assemble one 64-bit word with a value of X factorial. If X is negative or zero, then a word with value zero is assembled ``` instead: ``` FACT SET 1 I DO X FACT*I PROCESSED X TIMES IF X>0 FACT SET ELSE PROCESSED ONCE IF X50 FACT SET 0 DEND VFD.64 FACT ``` EXAMPLE 2) The following code will assemble N+1 64-bit words whose values are 0,...,N where N can be either positive or negative. The inner DO block is processed only if N<0.</li> ``` VFD,64 0 I 00 N PROCESSED N TIMES IF N>0 VFD.64 I ELSE J DO -N VFD,64 -J PROCESSED -N TIMES IF NO DEND DEND ``` If N=3 the above code is equivalent to: VFD,16 0 VFD,16 1 VFD,16 2 VFD,16 3 If N=-2 the example code is equivalent to: VFD,16 0 VFD,16 -1 VFD,16 -2 # CYBER 180 II Assembler ERS 4.0 PSEUDO INSTRUCTIONS 4.6.2 WHILE/ELSE/DEND PSEUDO INSTRUCTIONS #### 4.6.2 WHILE/ELSE/DEND PSEUDO INSTRUCTIONS The format of these pseudo instructions are: | llabel | loperation | argument | |----------------|------------|----------------| | label<br>label | • | expression<br> | Label and expression have the same meaning as in the DO pseudo operation. However, there is no limit placed on the value of the expression. The execution of the WHILE loop is similar to that of the DO, except that the expression is evaluated for each iteration in the loop. The WHILE pseudo operation is performed as follows: - a) An internal counter is set up and initially is given the value 0. - If a label is present on the WHILE line, its value is set to **b**) - The expression of the WHILE line is evaluated. results of this evaluation by m. (If no expression is present, or the expression is not evaluable, m = 0.) - If $m \le 0$ and this is the first time through the WHILE loop, d) suppress assembly until an ELSE or DEND pseudo operation is encountered. - If an ELSE pseudo operation is encountered, assemble succeeding statements until a DEND line is encountered. Continue assembly at the statement following the DEND line. - a DEND pseudo operation is encountered, resume 2) assembly at the line following the DEND line. If $m \le 0$ and this is not the first time through the WHILE loop, skip all lines until a DEND pseudo operation is encountered and resume assembly at the line following the DEND. ALDEN TOO IT WILDS ON FULL ON - 4.0 PSEUDO INSTRUCTIONS - 4.6.2 WHILE/ELSE/DEND PSEUDO INSTRUCTIONS - e) If m > 0, - 1) Increment the internal counter by 1. - 2) Set the value of the label on the WHILE line (if present) to the new value of the counter. - 3) Continue assembly until an ELSE or DEND pseudo operation is encountered, and then repeat the procedure from step c. Note that the only logical way to get out of a WHILE loop is to change within the loop, one or more of the items which make up the expression on the WHILE line so that the expression will not have a value $\leq 0$ . # Example: - . This code will assemble a number of 16-bit words whose value - . are from the Fibonacci series. Starting with the value 1, - . each word is equal in value to the sum of the previous two - . words. In this example the series is terminated when all of - its members less than N have been generated. ``` OPEN A,B,TEMP SET 0 A В SET 1 WHILE B<N VFD,16 8 TFMP SET R SET A+8 8 SET TEMP ٨ DEND CLOSE A.B. TEMP ``` If N=10 the above code is equivalent to: VFD,16 1 VFD,16 1 VFD,16 2 VFD,16 3 VFD,16 5 VFD,16 8 4.6.3 SKIPTO - SKIP CODE The SKIPTO pseudo operation enables the user to conditionally alter the sequence in which assembly lines are processed. It has the form: 86/10/17 Rev: F 4.0 PSEUDO INSTRUCTIONS 4.6.3 SKIPTO - SKIP CODE exp Optional, must be evaluable. namei A valid label appearing on a CONT, DEND, or PEND statement which follows the SKIPTO statement. If the expression is not present, only a single label is permissible. SKIPTO operates as follows: - a) If no expression is present on the SKIPTO line, skip succeeding lines until a line with the appropriate label is found. - b) If an expression is present, it is evaluated. - 1) If value of the expression is k and k lies between 0 and n-1 where n is the number of labels on the SKIPTO directive, the succeeding lines are skipped until a CONT, DEND, or PEND statement is found which has as its label, namek. - 2) If the value of the expression is < 0 or >= n (or the expression is not evaluable), assembly resumes at the line immediately following the SKIPTO pseudo instruction. Note that when in the skipping mode, all pseudo instructions except LOCAL, OPEN and CLOSE are ignored. Any symbol defined by LOCAL or OPEN pseudo instructions are not recognized. Labels within PROC/PEND, WHILE/DEND, or DO/DEND blocks are not recognized, and it is illegal to write a SKIPTO pseudo instructions which branches out of a procedure definition, WHILE/DEND sequence, or DO/DEND sequence. ## Example: - In the following example, the statement processed following - . the first SKIPTO directive depends on the value of "A". | | SKIPTO, | A | SMALL, MEDIUM, LARGE, HUGE | |--------|---------|------|------------------------------| | UNEXPT | SKIPTO | MORE | THIS STATEMENT IS PROCESSED | | • | | | IF A IS NOT EQUAL TO 0, 1, 2 | | • | | | OR 3. | | SMALL | RES | 50 | THIS STATEMENT IS PROCESSED | | | | | - | *** | - | - | - | - | - | | *** | | - | - | | - | - | - | | - | | |----|---|---|---|-----|---|---|---|---|---|---|-----|---|---|---|---|---|---|---|---|---|--| | 4. | 0 | P | S | E | U | D | 0 | | I | N | S | Ţ | R | U | C | T | I | 0 | N | S | | 4.6.3 SKIPTO - SKIP CODE | • | | | IF A IS EQUAL TO O. | |--------|--------|------|-----------------------------| | | SKIPTO | MORE | | | MEDIUM | RES | 100 | THIS STATEMENT IS PROCESSED | | • | | | IF A IS EQUAL TO 1. | | | SKIPTO | MORE | | | LARGE | RES | 250 | THIS STATEMENT IS PROCESSED | | • | | | IF A IS EQUAL TO 2. | | | SKIPTO | MORE | | | HUGE | RES | 1000 | THIS STATEMENT IS PROCESSED | | • | | | IF A IS EQUAL TO 3. | | MORE | CONT | | | | | • | | | - . If "RES" is a user-defined procedure which reserves the - . number of words of core specified by its argument, then the - . amount of core reserved by the above code varies depending on - . "A". - . This example illustrates the effect of <code>OPEN/CLOSE</code> and <code>DO/DEND</code> - blocks on the SKIPTO directive. | | • | | | |---|--------|------------|----------------------------------------------------------| | | SKIPTO | x | | | | • ' | | | | | OPEN . | X | | | X | RES | 5 | THIS LINE IS SKIPPED BECAUSE IT APPEARS | | | CLOSE | X | BETWEEN AN OPEN AND CLOSE | | | • | | | | | • | | | | I | 00 | 10 | | | | LOCAL | <b>X</b> | | | X | VFD,16 | I | THIS LINE IS SKIPPED BECAUSE IT APPEARS WITHIN A DO/DEND | | | DEND | | BLOCK | | | 02.10 | | the same Car So I is | | | • | | | | X | ADD | BASE, DISP | THIS LINE IS PROCESSED FOLLOWING THE SKIPTO DIRECTIVE | | | | | | 4.7 ERROR\_CONIROL CYBER 180 II Assembler ERS Rev: F 4.0 PSEUDO INSTRUCTIONS 4.7.1 ERROR PSEUDO OPERATION 4.7.1 ERROR PSEUDO OPERATION | + | | | |---|--------------------|-----------| | | loperation | largument | | 1 | [ERROR, exp, label | * | The ERROR pseudo operation provides a method for conditionally: generating an error message in the object listing and transferring control to another portion of the program. label Label is any valid symbol appearing in the label field of a subsequent CONT, DEND, or PEND statement. The statement must be a CONT, DEND, or PEND statement before label comparison is made. exp is a conditional expression whose value determines whether the error message is to be produced and if a transfer of control is necessary. If this subfield is omitted, then the message is unconditionally generated. message Message is any valid combination of characters (see Character set). When an ERROR pseudo instruction is encountered, the expression is evaluated. If it is true (1) or not specified, the error message is produced on the object listing. If symbol is present, control is transferred to the indicated line. If no symbol is present, assembly continues with the next statement. If the expression is false (0), no message is produced and assembly is continued at the succeeding line. Example: NELX ERROR,ACO C'ILLEGAL ARGUMENT' SET 2,3,A,M,XOR,COMX - . WHEN THE ABOVE DIRECTIVE IS ENCOUNTERED, IF A IS LESS THAN - . ZERO THEN THE MESSAGE "ILLEGAL ARGUMENT" WILL BE PRINTED. IF - . A IS NOT LESS THAN ZERO, NO MESSAGE WILL BE PRINTED. IN - EITHER CASE, THE LINE NELX WILL BE PROCESSED NEXT. CYBER 180 II Assembler ERS Rev: F 4.0 PSEUDO INSTRUCTIONS 4.7.1 ERROR PSEUDO OPERATION ERROR, B<0]B>15, ILR C'ILLEGAL REGISTER' PSRL LPD.2 B SKIPTO NEWL ILR ERR NEWL CONT - WHEN THIS ERROR DIRECTIVE IS ENCOUNTERED, IF 0≤8≤15, NO - MESSAGE IS PRINTED OUT AND THE LINE PSRLIIS PROCESSED. - FOLLOWED BY LINE NEWL. IF B<O OR B<15, THEN THE MESSAGE - "ILLEGAL REGISTER" WILL BE PRINTED AND THE LINE ILR IS - PROCESSED, FOLLOWED BY THE LINE NEWL. IN THIS EXAMPLE, "LPD" - . AND "ERR" ARE USER-DEFINED PROCEDURES. #### 4.7.2 FLAG - CONDITIONALLY SET ERROR FLAG A FLAG pseudo instruction produces an assembly error, but does not affect other code. | llabel | loperation | argument | |--------|------------|----------| | • | IFLAG | • | errtype FATAL - a fatal error detected. WARNING - a non-fatal error detected. Example: FLAG FATAL ### 4.8 LISTING\_CONTROL The instructions described in this section permit extensive control of the assembly listing format. ## 4.8.1 LIST - SELECT LIST OPTIONS | + | + | | |---|-----------|-------------------| | • | operation | argument | | • | • | exp_1,exp_2,exp_3 | The LIST pseudo operation controls the assembly listing generated. The argument field is used to select the various listing options. 4.0 PSEUDO INSTRUCTIONS 4.8.1 LIST - SELECT LIST OPTIONS - Valis an optional evaluable expression which is val interpreted as follows: - 0 = List this statement according to the listing controls in effect when this statement encountered. - 1 = List this statement according to the value of expression 3. This is the default. - An evaluable expression which may assume exp\_1 the following values: - 0 = Suppress complete listing. - 1 = List input statements. - 2 = List input statements plus all statements that generate code (VFD, CMD statements that normally would not be listed). - 3 = List all generated statements including internal procedure expansions. - 4 = List all generated statements. - exp\_2 An evaluable expression used to control the listing of unprocessed statements that are by-passed during the assembly procedure and also the statements in a DD/WHILE which normally would not be listed. This may occur during the processing of SKIPTO, DO and WHILE pseudo instructions. The values of the expression are as follows: - 0 = List only processed statements, but not repeated DO/WHILE statements. - processed statements including repeated DO/WHILE statements that are processed. - 2 = List all statements. - Used to control the listing of the listing control $exp_3$ pseudo instructions, TITLE, PAGE, SPACE, XRSY, and LIST. The values of this expression are as follows: - 0 = Do not list the Listing control statements. - 1 = List the Listing control statements. CYBER 180 II Assembler ERS CIDEN TOU IT ASSEMBLES END 4.0 PSEUDO INSTRUCTIONS 4.8.1 LIST - SELECT LIST OPTIONS The standard LIST parameters established by default are: LIST 1.2.1 Causing a full listing to be generated. Subsequently any of these parameters may be altered. A null subfield specifies that the parameter is to be unchanged. If no parameters are specified, the LIST options will revert back to their previous settings. 4.8.2 PAGE - EJECT PAGE | + | -+ | + | |---|------------|-----------| | | loperation | largument | | 1 | 1 PAGE | • | The appearance of this pseudo operation will cause the next line of output to appear at the top of a new page on the computer listing. If the next line would normally appear at the top of a new page, the PAGE pseudo operation is ignored. Two consecutive PAGE directives will generate a blank page. 4.8.3 SPACE - SKIP LINES | + | + | <b>.</b> | |--------|------------|----------| | llabel | loperation | | | 1 | 1 SPACE | • | expression Expression is any evaluable expression. The value of this expression specifies the number of lines to be spaced before the next line appears on the computer listing. If the expression is not present, a value of 1 is assumed. If the value of the expression is greater than the number of lines remaining on the page, the SPACE pseudo operation will have the same effect as the PAGE pseudo operation. Example: SPACE 3 CYBER 180 II Assembler ERS Rev: F 4.0 PSEUDO INSTRUCTIONS 4.8.4 TITLE - ASSEMBLY LISTING TITLE #### 4.8.4 TITLE - ASSEMBLY LISTING TITLE |TITLE |C'character string' character string Character string is a sequence of any characters (see Character Set) up to a maximum of 56 characters. The TITLE pseudo instructions enables the programmer specify an identification for assembly listing. When a TITLE pseudo instructions is encountered, the assembly listing is advanced to a new page (if it is not already at a new page). The indicated character string is printed at the top of this page and at the top of all succeeding pages until another TITLE pseudo instruction is encountered or the end of assembly is reached. A null argument field on a TITLE pseudo instruction line will cause the listing to be advanced to a new page, but no heading printed. #### Example: TITLE C'TESTCODE' #### 4.8.5 XRSY - CONCORDANCE SELECTION | + | | + | |---|------------|--------------| | | loperation | largument | | İ | 7 | namel,,namen | The XRSY pseudo operation is used to select certain symbols to be included in the concordance. Namen designates symbols to be included in the namen concordance. ## Example: XRSY XO CYBER 180 II Assembler ERS 4.0 PSEUDO INSTRUCTIONS 4.9 SECTIONS ------ #### 4.9 SECTIONS Sections are established for the user by the Assembler. optionally by the user. The concept of sections is valid only: for CPU programs. An IOU program has only one section, the code section, which can be read, written, and executed. Sections in a CPU module are established with differing levels of access to allow the user who uses them protection for code and data. concept of sections is similar to the hardware concept of Hardware segments are established to have different segments. levels of access, and generally so are the Assembler However, sections can be established with the same level of access, and they will then be combined into the same hardware segment. Sections can be used to establish a blocking of data and code. The section counter is automatically maintained by the Assembler, but can be modified by using the ORG, POS or BSS pseudo instructions. Data and code within a section is not relocatable. sections are treated as relocatable with references made via the use of pointers. The CYBER 180 instruction set has been designed to efficiently access data and code in other sections via a mechanism of pointers to a byte address plus an offset in the specific section. The pointers are generally established via the ADDRESS pseudo instruction in the BINDING section. ## 4.9.1 SECTION - ESTABLISH BLOCK SECTION establishes a new block. This statement is valid only for a CPU module. A user may establish up to 10 sections in addition to the five default sections established for him. SECTION pseudo instructions must appear before any code or data generation instructions are specified. | + | + | • | |---|-----------|----------------------------| | • | operation | argument | | • | • | type,attr,cid,algn,maxsize | (Required) Internal section name for USE block name definition. (Required) The section type identifier which must be type one of the following names: Rev: F 4.0 PSEUDO INSTRUCTIONS 4.9.1 SECTION - ESTABLISH BLOCK CODE Code section, only one code section is permitted per module. BINDING Binding section, only one binding section is permitted per module. WDRKING Working storage section. COMMON Common block section. EXTWORK Extensible working storage section. Data may not be established in sections of this type at Assembly time. EXTCOM Extensible common block section. Data may not be established in sections of this type at Assembly time. attr (Required) An absolute expression which specifies legal combinations of access attributes of the segment to contain the section. Only the "+" operator is permitted in the expression. READ - Read WRITE - Write EXECUTE - Executable BIND - Binding CACHE\_BYPASS - cache bypass (hardware feature) cid (Optional) Common section name (1-31 character alias name). algn (Optional) Two absolute expressions separated by a comma which define section alignment. The first parameter is an offset, the second is the base (modulus). Examples are: 0,8 - Word aligned section start. 8,64 - Section starts at word one of an 8 word block boundary. 0,8 - Word aligned section start (default for all sections except binding sections). maxsize (Optional) Absolute evaluable expression which specifies the maximum section size. The following default sections are established by the Assembler for a CPU module: Section Name Attributes ### CYBER 180 II Assembler ERS Rev: F 4.0 PSEUDO INSTRUCTIONS 4.9.1 SECTION - ESTABLISH BLOCK \*CODE Read+Execute WORKING Read+Write BINDING Read+Bind STACK Read+Write \* The name on the IDENT card can also be used to reference the CODE section. # Example: DUMMY SECTION WORKING, READ+WRITE,,0,8 4.9.2 USE - USE BLOCK The USE statement is valid only for CPU modules. USE starts/resumes use of an already established section into which code is subsequently assembled. | + | + | <del> </del> | |---|-----------|--------------| | | operation | argument | | • | IUSE | | name The name of the section into which the text that follows is assembled. (It corresponds to the name of a SECTION pseudo instruction). A blank name causes the assembly of code into the default CODE section. The name #LASTSEC will resume using the section in use prior to the last USE statement. The current position in a section is automatically maintained by the Assembler. When the USE pseudo instruction is executed, the section counter will automatically be restored to its previous value. # Example: DUMMY SECTION WORKING, READ+WRITE,,0,8 USE DUMMY USE #LASTSEC ### CYBER 180 II Assembler ERS Rev: F 4.0 PSEUDO INSTRUCTIONS 4.9.3 ORG - SET SECTION COUNTER # 4.9.3 DRG - SET SECTION COUNTER The ORG pseudo instruction specifies the unit (bytes for CPU or words for IOU) offset to which the section counter is to be set. | llabel | loperation | argument | |--------|------------|----------| | llabel | | lexp | label Optional, if present, is set to the value of exp. Symbol category equals 6. exp An absolute expression specifying the address to which the unit offset is to be set. Any symbols in the expression must have been previously defined. #### Example: TAG BSS 10 .DATA AREA. ORG TAG .STORE IN DATA AREA. ## 4.9.4 POS - SET BIT POSITION IN THE SECTION COUNTER The PBS pseudo instruction sets the value of the bit offset in the section counter to the value specified by the expression in the argument field for either CPU or IDU modules. | <b>4</b> | <b></b> | | |----------|----------------|----------| | llabel | <br> operation | argument | | * | I POS | н | aexp An absolute, evaluable expression having a positive value less than or equal to the bit position with a unit (byte for CPU or word for IDU). A negative value, or a value greater than 7 for a CPU module, or a value greater than 15 for an IDU module causes an error. The value indicates the bit position within the current address unit at which the Assembler is to generate the next data. Use caution, because if the new bit position value is less than the old bit position value, part of the byte is reassembled. CYBER 180 II Assembler ERS CLOCK TOO IT WASHINGTON CKA 4.0 PSEUDO INSTRUCTIONS 4.9.4 POS - SET BIT POSITION IN THE SECTION COUNTER (New code is ORed with previously assembled data). If the new bit position value is greater than the old bit position value, the Assembler generates zero bits to the specified bit position. CAUTION: If the POS pseudo instruction is used on a word containing relocatable or external addresses, undefined results may occur with no diagnostics. The POS pseudo instruction does not alter the unit offset (byte for CPU or word for IDU). The POS instruction never causes the unit (byte for CPU or word for IDU) to be changed. # Example: POS 3 4.9.5 BSS - STORAGE RESERVATION The BSS pseudo instruction reserves memory in the section in use by adjusting the addressable unit offset (bytes for CPU or words for IDU). It does not generate data to be stored in the reserved area. | + | + | <del> </del> | |-------|------------|--------------| | • | loperation | argument | | label | • | * | label Optional label defined as the addressable unit offset after the force to an addressable unit boundary occurs. It is the beginning symbol for the storage area. Symbol category equals 6. aexp Absolute expression specifying the number of addressable storage units to be reserved. All symbols must be previously defined. Aexp cannot contain external symbols or be relocatable. The value of the expression can be zero or positive, but not negative, and the value is added to the addressable units offset. A BSS 0 causes a force to byte boundary and symbol definition, but no storage is reserved. # Example: TAG BSS 5 ### CYBER 180 II Assembler ERS othru ton II-wadhunter-rua. 4.0 PSEUDO INSTRUCTIONS 4.9.6 ALIGN - FORCE SECTION COUNTER ALIGNMENT # 4.9.6 ALIGN - FORCE SECTION COUNTER ALIGNMENT The ALIGN pseudo instruction forces the unit offset to the specified boundary (byte for CPU module, word for IDU module) and sets the bit offset to zero. | + | + | <del> </del> | |---|------------|----------------------| | | loperation | argument | | • | | lincrement, unitsize | label Optional label defined as the unit offset after the force to the specified offset plus increment occurs. Symbol category equals 6. increment: The increment is a value that is added to the unit offset after the alignment is made to a unitsize boundary. unitsize The unitsize specifies a value by which the unit offset must be evenly divisible. The number specified must be greater than zero. To do this, a number between 0 and unitsize -1 is added to the unit offset to make it evenly divisible. ## Example: ALIGN 0,2 .PARCEL BOUNDARY (CPU). ALIGN 0,8 .WORD BOUNDARY (CPU). # 4.10 PROCEDURES A procedure definition is a sequence of source statements that are saved and then assembled whenever needed through a procedure call. A procedure call consists of the occurrence of the procedure name in the operation field of a statement. It usually includes parameters to be substituted for formal parameters in the procedure code sequence so that code generated can vary with each procedure call. Use of a procedure requires two steps, definition of the procedure sequence, and calling of the procedure. A definition consists of three parts: heading, body, and terminator. Heading A PROC definition is headed by a PROC pseudo 86/10/17 Rev: F 4.0 PSEUDO INSTRUCTIONS 4.10 PROCEDURES instruction initiating the definition of a procedure, and a PNAME pseudo instruction stating the name of the procedure. Body The body begins with the first statement in a definition after the heading. The body consists of a series of symbolic instructions. All instructions other than PEND, including other procedure calls are legal within a definition. Within a PROCEDURE, calls can appear to other Procedures, but a PROCEDURE cannot call itself nor can any PROCEDURE in a nest of calls call any other PROCEDURE previously in the PROCEDURE definitions cannot be nested. is, a PROC pseudo operation must be followed by a PEND pseudo operation prior to the appearance of another PROC pseudo operation. The overall order of PROCEDURE definition is immaterial so long as the definition precedes the first call to assemble the PROCEDURE (i.e. a procedure call within a procedure definition may reference a procedure that is not defined prior to this point). Terminator A PEND pseudo instruction terminates a procedure definition. A procedure can be defined anywhere in a program before it is called. When the Assembler encounters a definition, it places the name of the procedure along with the number of substitutable parameters and local symbols in the Assembler operation code table. #### 4.10.1 PARAMETER REFERENCING WITHIN PROCEDURES Parameters on a procedure call can be referenced using the Field function "F:" and specifying the position of the parameter. The position of the parameter is indicated by using an (i,j) notation to describe where on the procedure call the parameters should be gotten. Using the (i,j) notation, I describes the field number (label field = 0, operation field = 1, argument field = 2), and J describes the position in the field starting at 0. An entire field may be referenced by just quoting the first parameter. When a label is specified on the PROC statement, that label is equated to the Field function and can optionally be used instead of F: (the colon is part of the Field function name). For more information, refer to the section discussing the PROC statement. ### CYBER 180 II Assembler ERS Rev: F 4.0 PSEUDO INSTRUCTIONS 4.10.1 PARAMETER REFERENCING WITHIN PROCEDURES Using F: notation, the i\*\*th field and the i\*\*th subfield of a statement is referenced as: F: ([, i) A reference to the entire i\*\*th field would be: F:(i) References to a particular field or subfield may occur anywhere that such a reference has meaning. Each reference acts as a direct substitution of the referenced subfield into the referencing entity. The actual substitution mechanism can have several meanings which are discussed in subsequent chapters. # 4.10.1.1 Parameter Identification Examples - THIS EXAMPLE SHOWS HOW RELATIVE FIELD IDENTIFICATION WORKS. - CONSIDER TRANSLATION OF THE FOLLOWING LINE: IMPERAT ADD, 3,4 ADDEND, AUGEND MOVE, 5, 6 DEST, SOURCE - DURING PROCESSING OF THE OPERATION: - F:(0) = IMPERAT - F:(1,0) = ADDF:(1,1) = 3F:(1.2) = 4 - F:(2,0) = ADDENDF:(2,1) = AUGEND - F:(3,0) = MOVEF:(3,1) = 5F:(3,2) = 6 - F:(4,0) = DESTF:(4,1) = SOURCE #### 4.10.2 PROC - PROCEDURE HEADING The PROC pseudo instruction is the first pseudo instruction which must be given in the process of defining a PROCEDURE. This instruction may contain an optional label field. Following the PROC pseudo instruction must appear the statements comprise the entire PROCEDURE being defined. appearance of the PROC pseudo instruction initiates definition of a PROCEDURE. All statements which follow the PROC pseudo instruction up to and including the first encountered PEND pseudo instruction will be included as part of the PROCEDURE being defined. The PROCEDURE being defined will be considered terminated when the first subfield of any subsequent OPERATION field contains the pseudo instruction PEND. All statements of the PROCEDURE which lie between the PROC pseudo instruction and the next PEND pseudo instruction are considered to be the body of the PROCEDURE. CYBER 180 II Assembler ERS ----- 4.0 PSEUDO INSTRUCTIONS 4.10.2 PROC - PROCEDURE HEADING Within this PROCEDURE body, the first subfield of any subsequent Within this PROCEDURE body, the first subfield of any subsequent OPERATION field prior to a PEND pseudo instruction cannot contain another PROC pseudo instruction. | + | + | <del></del> | |---|------------|-------------| | | loperation | argument | | • | I PROC | • | label Optional, the label field of a PROC pseudo instruction contains a symbol, this symbol can then be used as a field function name within the procedure body and also by any other (nested) procedures. Note that the label is defined only while the procedure is active (referenced), and cannot be used to call the procedure. The label on the PROC pseudo instruction line is normally used within the PROCEDURE followed by field and subfield notation to reference the actual arguments by which the PROCEDURE was called. If no label appears with the PROC pseudo instruction, then the parameters by which the procedure is called can be referenced only by using the F: notation described in the previous section. Examples can be found in the section entitled "Procedure Examples". 4.10.3 PNAME - PROCEDURE NAME DEFINITION The PNAME pseudo instruction is used to provide a name by which a PROCEDURE can be referenced. The PNAME pseudo instruction must immediately follow the PROC, FNAME, or another PNAME pseudo instruction when a PROCEDURE is being defined. Any PROCEDURE may have multiple PNAME pseudo instructions and, therefore, be referenced by several names. | + | + | + | |---|------------|-----------| | | loperation | largument | | • | IPNAME | • | label Name by which the procedure is referenced. value An evaluable expression. Within the PROCEDURE, the value of the expression following CYBER 180 II Assembler ERS Rev: F 4.0 PSEUDO INSTRUCTIONS 4.10.3 PNAME - PROCEDURE NAME DEFINITION the name by which the PROCEDURE was actually referenced is available as F:(1,0). This permits the programmer to distinguish between referencing names, when desired. A PROCEDURE is referenced (as a procedure) by placing one of its defined PNAME's in the first subfield of a OPERATION field. The expression which represents the value associated with the PNAME is evaluated each time the PROCEDURE is referenced using that name. Examples can be found in the section entitled "Procedure Examples". 4.10.4 FNAME - FUNCTION NAME DEFINITION The FNAME pseudo operation is used to provide a name by which a PROCEDURE may be referenced as a FUNCTION. The FNAME pseudo operation must immediately follow the PROC, PNAME or another FNAME pseudo operation when a PROCEDURE is being defined. PROCEDURE may contain multiple FNAME pseudo instructions and, therefore, be referenced by several names. > +----llabel | loperation largument Habel IFNAME Ivalue Name by which the procedure is referenced as a label function. value An evaluable expression. Within the PROCEDURE, the value of the name by which the PROCEDURE was actually referenced is available as F:(1,0). permits the programmer to distinguish between referencing names, when desired. A PROCEDURE is referenced (as a function) by forming a structure: #### name(argument) Where name is its defined FNAME and argument is the argument to the PROCEDURE. This bounded argument, less parentheses, is available, starting at F:(2,0), just as if the PROCEDURE was referenced as a procedure (via PNAME). The argument is limited to one field, although it may contain as many subfields as necessary. No blanks may appear between the argument and the 4.0 PSEUDO INSTRUCTIONS 4.10.4 FNAME - FUNCTION NAME DEFINITION enclosing parentheses. The expression which represents the value associated with the FNAME is evaluated each time the PROCEDURE is referenced using that name. A PROCEDURE, referenced using one of its FNAME's will have the entire reference replaced by the value of the expression on the PEND pseudo instruction when the PEND pseudo instruction is executed. This value will always be 8 bytes long. Note that a function may not generate code or change location counters if it is invoked from a statement which, itself, is generating code. Examples can be found in the section entitled "Procedure Examples". 4.10.5 PEND - END PROCEDURE DEFINITION A PEND terminates any unterminated definition. A PEND outside the range of any procedure sequence has no effect other than to be included in statement counts. | + | t | | |---|-----------|-------| | • | operation | "Aut" | | • | PENO | exp | label (Optional) May be used as the object of a skip by a SKIPTO or ERROR statement. The label symbol is not entered into Assembler's symbol table and the presence of a label does not constitute symbol definition. exp The argument field can be null or can be an evaluable expression. When the PROCEDURE is called as a procedure reference, any PEND expression is ignored. When a PROCEDURE is called as a function reference, the PEND expression is evaluated and the value is returned as the value of the function. A null expression returns the value zero. Examples can be found in the section entitled "Procedure Examples". 4.10.6 LOCAL - ESTABLISH LOCAL SYMBOLS The LOCAL pseudo instruction is used to establish symbols Rev: F 4.0 PSEUDO INSTRUCTIONS 4.10.6 LOCAL - ESTABLISH LOCAL SYMBOLS which are to be considered local to the PROCEDURE in which they are defined. The appearance of a LDCAL pseudo instruction supersedes all previous LOCAL pseudo instructions in that program or PROCEDURE and all symbols previously declared local are erased. A PEND or END line terminates the LOCAL. | + | + | | |---|------------|-------------| | | loperation | argument | | - | • | namel,namen | namel,...namen Establish symbols local to a procedure. A symbol may not be defined as LOCAL if its symbol category is one of the following: - 2 CMD defined instruction - 4 PROCEDURE call - 10 PROCEDURE Reference List - 12 ANAME defined symbol (programmer defined attribute) - Section counter 13 Examples can be found in the section entitled "Procedure Examples". 4.10.7 OPEN - DECLARE TEMPORARY SYMBOLS The OPEN pseudo instruction is used to declare temporary symbols without affecting any prior use of the label. A label declared by an OPEN pseudo instruction remains active until closed by a CLOSE pseudo instructio using the same label. OPEN pseudo instructions may be nested using the same label. label created under the last OPEN pseudo instruction executed will be active until closed. It is important to note that closing opened symbols takes place in reverse order from the opening process. That is, the last open symbol is closed first, then the next-to-last, etc. Subsequent OPEN pseudo instructions only affect each other if they use the same symbol, otherwise they act independently without cancelling prior OPEN pseudo instructions as is the case with LOCAL pseudo instruction. Definitions of DPEN'ed symbols are restricted in the same way as LOCAL symbols. | + | + | + | |---|------------|-------------| | | loperation | nor | | • | • | namel,namen | CYBER 180 II Assembler ERS Rev: F 4.0 PSEUDO INSTRUCTIONS 4.10.7 OPEN - DECLARE TEMPORARY SYMBOLS namel,...,namen Establish temporary symbols with names namel,...,namen Examples can be found in the section entitled "Procedure Examples". 4.10.8 CLOSE - ERASE TEMPORARY SYMBOLS The CLOSE pseudo instruction erases the symbols whose names are used as arguments to the pseudo instructions. If a symbol has been opened by more than one OPEN pseudo instruction, then CLOSE only erases the last OPEN and the symbol usage then reverts to its usage under the previous OPEN. If there was only one OPEN associated with the symbol, the symbol becomes non-existent and is completely erased. It is illegal to CLOSE a symbol that has not been opened. | + | + | | |---|------------|--------------| | | loperation | argument | | • | • | namel,,namen | namel,...namen Erase temporary label field symbols with names namel,...namen. Examples can be found in the section entitled "Procedure Examples". 4.10.9 CONT - NO OPERATION The CONT pseudo instruction is used to place a symbol on a statement only for the purpose of assembly time transfer of control. The CONT pseudo instruction functions in all other respects as a no-op. | + | -+ | | |---|-----------|----------| | - | operation | argument | | • | CONT | | (Required) Symbol used for transferring control during the assembly process. The symbol is not entered in Assembler's symbol table and use of a symbol in the label field does not constitute symbol definition. Examples can be found in the section entitled "Procedure CYBER 180 II Assembler ERS Rev: F 4.0 PSEUDO INSTRUCTIONS 4.10.9 CONT - NO OPERATION Examples". 4.10.10 PROCEDURE CALLS A procedure headed by the PROC pseudo instruction can be called by an instruction in the following format: | + | -+ | | |---|---------------------------|--| | - | operation argument | | | * | procname field1,field2, | | label Optional, its value can be retrieved from within the procedure's body by the F:(0) field function. procname Name of a predefined procedure (label on PNAME). fields One or more fields which might consist of several subfields. A defined PROCEDURE may be referenced using any one of its names as defined by a PNAME or FNAME pseudo instruction. This name is written as the first subfield of the OPERATION field. The remainder of the OPERATION field and as many argument fields as necessary can follow the OPERATION subfield and contain the arguments to the PROCEDURE. The Assembler is capable of handling as many arguments as the user wishes to provide. Parameters passed to PROCEDURES are <u>call\_by\_name</u> in that a parameter is evaluated each time it is referenced within the body of a PROCEDURE. Any previous statements within the body of the PROCEDURE which have changed the value of a given parameter will affect later references to the parameter. Any OPEN or LOCAL pseudo instructions within the body of a referenced PROCEDURE which declare labels with the same symbol as a label passed as a parameter will not affect the parameter being passed. It is the actual call to a PROCEDURE which requires that it be defined and not just the appearance of a call in an Assembler statement. Unexecuted calls do not require that the named PROCEDURE be defined. 4.10.11 PROCEDURE EXAMPLES ### CYBER 180 II Assembler ERS Rev: F 4.0 PSEUDO INSTRUCTIONS 4.10.11.1 Procedure Definition ## 4.10.11.1 Procedure Definition THIS IS AN EXAMPLE OF THE USE OF PROCEDURES. THE - PROCEDURE STATEMENTS (THOSE APPEARING BETWEEN A PROC AND - A PEND DIRECTIVE) ARE NOT PROCESSED UNTIL THE PROCEDURE - NAME APPEARS IN THE OPERATION FIELD OF A STATEMENT BEING - PROCESSED. IN THIS EXAMPLE, AFTER THE STATEMENT LABELLED - "CALLING" IS ENCOUNTERED, PROCESSING OF THE STATEMENTS IN - PROCEDURE "SAM" BEGINS. WHEN THE PEND DIRECTIVE IN "SAM" - IS ENCOUNTERED, PROCESSING RESUMES AT "NEXTLINE". SAMR PROC PNAME SAM SET F:(2,0)A SET .F:(2,0) REFERENCES X\*3 F:(2,1).F:(2,1) REFERENCES ZXT F:(2,2) ANAME 6 .ASSIGNS NAME INDEX TO .ATTRIBUTE NUMBER 6 MAX SAMR: (2,2), SAMR: (2,1) PEND PROC MAX PNAME F:(2.1) ATRIB F:(2.0).5 PEND .INTERPRETED AS: ZXT ATRIB .INDEX.5 F: REFERENCES LINE CALLING MAX. SAMR REFERENCES LINE CALLING SAM CALLING SAM X<sup>3</sup>,ZXT,INDEX NEXTLINE VFD.16 ZXT . THE ABOVE CODE IS EQUIVALENT TO: SET X**≈3** Δ 8 SET ZXT INDEX ANAME 6 ATRIB INDEX.5 NEXTLINE VFD,16 ZXT - THE FOLLOWING EXAMPLE INVOLVES TWO DIFFERENT DEFINITIONS OF - THE LABEL X. THE NET EFFECT OF THIS CODE IS TO SET THE VALUES - . OF X AND Y TO 7: PROC ZED PNAME LOCAL X Х SET 2 CIDEN TOO II WAREHOLES END ``` 4.0 PSEUDO INSTRUCTIONS ``` 4.10.11.1 Procedure Definition ``` F:(2,0) SET F:(2,0)+X Y SET F:(2,0) PEND .WHEN EXECUTED LOCAL X NO LONGER EXISTS X SET 5 .GLOBAL X ZED X .GLOBAL X AS PARAMETER F:(2,0) ``` - THIS PROCEDURE DEFINES A SET OF INSTRUCTIONS FOR THE C180 CPU - EACH OPERATION CODE IS SPECIFIED AS A PROCEDURE ENTRY NAME - . WHEN HAS THE MACHINE CODE AS THE VALUE. - THESE INSTRUCTIONS ARE IN THE FORM OP R1.R2 WHERE R1 AND R2 SPECIFY REGISTERS. ``` PROC ADDR PNAME 20(16) SUBR PNAME 21(16) MULR PNAME 22(16) DIVR PNAME 23(16) SR PNAME 1B(16) * F:(0,0) VFD,8,4,4 F:(1,0),F:(2,1),F:(2,0) PEND ``` # 4.10.11.2 LOCAL Directive's Use | A | SET | 5 | THIS IS A GLOBAL "A" | |------|-------|-------|----------------------------------------------| | | • | | | | | • | | | | | PROC | | | | EVAL | PNAME | | | | | LOCAL | A,8,C | ANY REFERENCES TO A. B. OR C WITHIN THE | | • | | | EVAL PROCEDURE SIGNIFY SYMBOLS LOCAL | | Α | SET | 7 | LOCAL "A" | | D | SET | A | GLOBAL "D", LOCAL "A" | | В | SET | | LOCAL "B", LOCAL "A" | | | | | AT THIS POINT, $VA:(A) = 7$ , $VA:(B) = 7$ , | | | • | | | | | • | | | | | PEND | | | | | • | | | | | • | | | | C | SET | A | GLOBAL "C", GLOBAL "A" | | E | SET | D | | | • | | | AT THIS POINT, $VA:(A) = 5$ , $VA:(C) = 5$ , | | • | | | VA:(D) = 7. AND VA:(F) = 7 | CYBER 180 II Assembler ERS 5.0 ATTRIBUTE FUNCTIONS ## 5.0 ATTRIBUTE FUNCTIONS The Assembler provides a set of built in functions to assign and/or retrieve values of a symbol attribute. They are usually used to aid in parameter analysis in procedure and function definitions. An attribute function is a replacement operation in which the value of the specified attribute replaces the function in the expression. The permitted arguments to an attribute function are defined later in this section. The set of Symbol Attribute Functions (SC:, VA:, LB:, LC:, LW:, SB: and SN:), and the basic Field Reference Function ("F:" used for parameter referencing), all include the character ":" (colon), which is an alphabetic character within the meaning of the Assembler. This character is included as a means of avoiding potential conflicts with user-defined symbols, and does not represent an operator of any kind. Note that this character must be entered in the NDS ASCII representation. The general form of an attribute function is: attribute\_function\_name(argument) where attribute\_function\_name is the name of a specific attribute function, and the argument, enclosed in parentheses, immediately follows. All of the symbol attributes discussed in the section on Symbol Definition have a corresponding attribute function which can be used to retrieve that particular symbol attribute from the internal Assembler symbol table. #### 5.1 LANGUAGE DEFINED ATTRIBUTES All the attribute functions described in this section are built into the Assembler. #### 5.1.1 SYMBOL CATEGORY ATTRIBUTE - SC: Format: SC:(argument) The SYMBOL CATEGORY Attribute function is used to determine the symbol category assigned to the argument. The argument can Rev: F 5.0 ATTRIBUTE FUNCTIONS 5.1.1 SYMBOL CATEGORY ATTRIBUTE - SC: be a symbol name or a PROCEDURE reference field specification. This function returns the value of the category and may be used for testing. When the argument refers to an expression rather than a symbol, the category of the expression will be the category of the first term in the expression. The category of a NULL subfield in a PROCEDURE reference is zero. The Symbol Category attribute has the following values and meaning: | Category | Meaning | |----------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 0 | Non-existent symbol. The symbol in question has not been encountered by the Assembler. The existence of a blank LABEL field can be detected by this category. | | 1 | The symbol has appeared in a LABEL field, may have certain attributes, but no operation has taken place to further define the symbol. After each statement is processed, any remaining category 1 symbols are erased from the symbol table, unless they have programmer defined attributes. | | 2 | The symbol has been defined by a CMD pseudo instruction and is now recognized as an instruction generating symbol. | | 3 | The symbol is an Assembler defined function. | | 4 | The symbol is a PROCEDURE call, defined by an FNAME or PNAME pseudo instruction. | | 5 | The symbol is an Assembler pseudo instruction. | | 6 | The symbol is a relocatable address defined by use in a code generating statement such as VFD, INT, DINT, FLDAT, DFLDAT, PDEC, BSS, BSSZ, ADDRESS, DRG, ALIGN, or by the execution of an instruction generating symbol defined by a CMD pseudo instruction. | | 7 | The symbol was defined by a REF pseudo instruction. | | 8 | The symbol is the symbol "\$" (section counter). | | 9 | The symbol is a list name defined by a SET or EQU pseudo instruction or as the label of a DO or WHILE pseudo instruction. | | 10 | The symbol is a list name of a symbolic list | Rev: F 5.0 ATTRIBUTE FUNCTIONS 5.1.1 SYMBOL CATEGORY ATTRIBUTE - SC: PROCEDURE references. holding The symbol defined by a PROC pseudo instruction (see PROCEDURES). - 11 The symbol is a self-defining term. - 12 The symbol is defined by an ANAME pseudo instruction. - 13 The symbol is a list defined by a SECTION pseudo instruction. Symbols defined in the label field of pseudo instructions where the label field is not ignored will have the symbol category documented for that instruction. Symbols defined in the label field of the symbolic machine instructions will have a Symbol Category of 6. ### 5.1.2 ADDRESS MODE ATTRIBUTE # Format: AM: (argument) The ADDRESS MODE attribute function is used to determine the relocatability of the argument. The argument can be a symbol name or a PROCEDURE field reference specification. This function returns the value 1 if and only if the argument is defined and Otherwise, it returns a value of zero. relocatable. When the argument refers to an expression rather than a symbol, the ADDRESS MODE will be the ADDRESS MODE of the first term in the When the symbol is the symbol "\$", the address mode expression. value will be 0. ## 5.1.3 VALUE ATTRIBUTE # Format: VA: (argument) The VALUE attribute is used to determine the value assigned to the argument, where argument is either a symbol or a PROCEDURE field reference specification. The meaning of attribute varies with the symbol category of the argument: #### SYMBOL CAIEGORY VALUE and/or MEANING | 0 | 0 | |-------------|---| | 1 | 0 | | 1<br>2<br>3 | 0 | | 3 | 0 | # CIDER 100 11 ASSEMbler ERS # 5.0 ATTRIBUTE FUNCTIONS 5.1.3 VALUE ATTRIBUTE | 4 | The value of the PNAME/FNAME symbol when the | |----|-----------------------------------------------| | | procedure is called. | | 5 | <b>0</b> | | 6 | (Integer) address assigned to the symbol. | | 7 | 0 | | 8 | The current integer location counter value. | | 9 | The value of the first element of the list. | | 10 | 0 | | 11 | The (word) value of the self-defining term. | | 12 | The value is the programmer defined attribute | | | number assigned to the symbol. | | 13 | The value of the first element of the list | The value of an expression is the net value found by evaluating the expression. A NULL field or subfield has the value of zero. (the integer location counter). The VALUE attribute function is processed in a similar manner to normal expression evaluation, except that errors caused by invalid use of symbols are suppressed. #### 5.1.4 LENGTH ATTRIBUTES Format: LB:(argument) LC:(argument) LW:(argument) The LENGTH attribute is used to determine the length in bits (LB:), bytes or cells (LC:), or words (LW:) of the argument, where the argument is a symbol representing a data or instruction area assigned by the Assembler in either a CPU or an IOU module. A CYBER 180 CPU word is 64 bits long and an IOU word is 16 bits long. The LENGTH function rounds up to the next integral number of units in cases where the bit length of the argument is not an exact multiple of the defined character or word. LENGTH returns the value 0 if a symbol has not been defined at the time the evaluation of LB:, LC:, or LW: takes place. As explained in the section on SYMBOL DEFINITION, a symbol acquires a length attribute when it becomes defined by appearing in the LABEL field of a data generating pseudo instruction. This length attribute is the quantity of storage assigned to the information labeled with the symbol. A Self-Defining Term has a LENGTH attribute assigned to that term based on its structure. CYBER 180 II Assembler ERS 5.0 ATTRIBUTE FUNCTIONS 5.1.4 LENGTH ATTRIBUTES If the symbol has been defined with a code generating pseudo instruction (category 6) then the bit length is given by the total number of bits generated by the statement. Applicable pseudo instructions include VFD, INT, DINT, FLOAT, DFLOAT, PDEC, BSS, BSSZ, ADDRESS, and CMD calls. A character is assumed to be 8 bits, and the word size is taken to be 64 bits for a CPU module, 16 bits for an IDU module. If the argument is a self-defining term, the length is determined based on its structure. A character string (types C and E) have a character/byte length equal to the number of characters in the string, a bit length of 8\*LC. For all other types of self-defining terms, the bit length is equal to the appropriate CYBER 180 word size. #### 5.1.5 STARTING BIT POSITION ATTRIBUTE # Format: SB:(argument) The STARTING BIT POSITION attribute is used to determine the value of the BIT offset in the stored byte at the time storage was assigned to the argument. This function has a zero value for all arguments whose symbol category is not equal to 6. The STARTING BIT POSITION attribute for an expression is the STARTING BIT POSITION attribute of the first term in the expression. The STARTING BIT POSITION attribute of a NULL field or subfield is zero. The maximum value for this attribute is 15. ### 5.1.6 ELEMENT NUMBER ATTRIBUTE # Format: EN: (argument) The ELEMENT NUMBER attribute determines the number of subfields (elements) associated with or assigned to the argument. The argument can be any list name and the value of the EN: function will be the number of elements assigned to the list at the time evaluation takes place. Note that a symbol name becomes defined as a list only by appearing in the LABEL field of the SET pseudo instruction. When a PROCEDURE field reference is used as an argument to the EN: function, then one of two forms of substitution take place: a) If the specification contains a field index and no subfield index (F:(0),F:(1),...etc.), then the count is made against the actual subfield elements in the PROCEDURE reference line itself. CYBER 180 II Assembler ERS 5.0 ATTRIBUTE FUNCTIONS 5.1.6 ELEMENT NUMBER ATTRIBUTE If the specification contains both a field AND subfield index (F:(0,0),F:(2,0),...etc.), then the count is made against the contents of the designated subfield. #### 5.1.7 LAST ELEMENT NUMBER ATTRIBUTE Format: EL:(argument) The LAST ELEMENT NUMBER attribute determines the element number of the last element assigned to the list used as an argument. For lists with one or more elements: EL:(argument) = EN:(argument)-1 For all non-list arguments: EL:(argument) = 0 When a PROCEDURE field reference is used as an argument to the EL: function, then one of two forms of substitution take place: - If the specification contains a field index and no subfield index (F:(0),F:(1),,,,.etc.), then the count is made the actual subfield elements in the PROCEDURE reference line itself. - If the specification contains both a field AND subfield index (F:(0,0),F:(2,0),...,etc.), then the count is made against the contents of the designated subfield. #### 5.1.8 SYMBOL NUMBER ATTRIBUTE Format: SN:(argument) The SYMBOL NUMBER attribute determines a unique representing the symbol. This value is only meaningful when used for comparison to test equality with the SYMBOL NUMBER of other symbols. If the argument does not correspond to a symbol, then a value of zero is returned. ### 5.1.9 RELOCATION ATTRIBUTE The Relocation attribute is not a property of a symbolic name. The Relocation attribute is a function that is used to associate relocation information with the generation of data and as such it is meaningful only when used in an expression in the argument CYBER 180 II Assembler ERS 5.0 ATTRIBUTE FUNCTIONS 5.1.9 RELOCATION ATTRIBUTE field of a VFD. CMD. INT. or DINT statement. See the example below. The function is valid only in a CPU module. If the CPU module is declared "NONBINDABLE", then the relocation information is ignored. This function must have three (3) arguments. The relocation function is called as follows: R: (EXP.RCT. ADT) - An expression defining the byte offset to be used as a EXP displacement. If the expression is not relocatable in the BINDING section them no "relocation" object text is generated. The function result is the expression result divided, if necessary, as determined by the ADT subfield. - Defines the relocation container type (width and alignment). This applies to the field being generated. (Note that only discrete values are permitted.): Unless otherwise indicated the field must start on an addressable boundary. 0 = Parcel Size (2-bytes) 1 = Three Bytes 2 = Half Word (3-bytes) (4-bytes) 3 = Word(8-bytes) 4 = Instr. D-Field (12-bits/MOD 4) 5 = Instr. Q-Field (2-bytes) 6 = Long D-Field (3-bytes) ENTC & ENTA Instr. Any other value is diagnosed as an error. ADT Defines the address displacement type of the field. The function result is EXP divided by a constant determined by the ADT subfield as follows: 0 = Byte Positive R: = EXP 1 = Parcel Positive R: = EXP / 2 2 = Halfword Positive R: = EXP / 4 3 = Word Positive R: = EXP / 8 4 = Byte Signed R: = EXP / 2 5 = Parcel Signed R: = EXP / 2 6 = Halfword Signed R: = EXP / 4 7 = Word Signed R: = EXP / 8 Any other value 2 Any other value is diagnosed as an error. #### **EXAMPLE:** R:(binding\_sect\_disp,5,5) VFD.16 #### 5.2 PROGRAMMER\_DEFINED\_ATTRIBUTE\_FUNCTIONS Any symbol may be given one or more programmer defined attributes by first using the ANAME pseudo instruction to give each programmer defined attribute a name and then using the ATRIB 86/10/17 CYBER 180 II Assembler ERS Rev: F 5.0 ATTRIBUTE FUNCTIONS 5.2 PROGRAMMER DEFINED ATTRIBUTE FUNCTIONS pseudo instruction which assigns a value to a specific attribute of a symbol. The Assembler permits the definition up to 16 programmer defined attribute names. Each programmer defined attribute is given a name and an attribute number using the ANAME pseudo instruction: | INDEX | ANAME | 1 | |-------|-------|---| | BASE | ANAME | 2 | | FREQ | ANAME | 3 | | | • | | | | • | | | | • | | | | etc. | | Once defined, a programmer defined attribute function of the form: programmer defined\_attribute\_name(argument) may be used in the same way as an Assembler defined attribute function to recover the value of a particular programmer defined attribute assigned to the argument. When the argument to an programmer defined attribute function is an expression, the function value is the value of the named programmer defined attribute of the first symbol in the expression. The names and values can be altered during the course of the program assembly using the ANAME and ATRIB pseudo instructions discussed in the section on pseudo instructions. #### 5.3 SYMBOL\_ATTRIBUTE\_EXAMPLES length aname 1 .LENGTH IS A PROGRAMMER DEFINED ATTRIBUTE proc data pname This procedure generates a character string of data in the WORKING section starting on a half-word . boundary. It will also assign the length in . bytes as an attribute called length. # CYBER 180 II Assembler ERS \*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\* 5.0 ATTRIBUTE FUNCTIONS 5.3 SYMBOL: ATTRIBUTE EXAMPLES label data charstring working •puts us in working section use .puts us on a half-word boundary align 0,4 vfd, lb:(f:(2,0)) f:(2,0) .generate data atrib length, lc:(f:(2,0)) .puts byte length f:(0,0)f:(0,0) #lastsec use pend labell C'EXAMPLE' .data procedure call: data numbyte length(labell) .picks up byte length of string set 86/10/17 CYBER 180 II Assembler ERS Rev: F 6.0 OFFSET FUNCTIONS (#WOFF, #HOFF, #POFF, #BOFF) # 6.0 DEESEL EUNCIIONS (#WOEF. #HOEE. #POEE. #BOEE) The offset functions return the Word, Half-Word, Parcel, or Byte offset of an address relative to the beginning of a CPU section in which it is defined. For an IOU module, only Word and Byte offset are defined. Use of #HOFF or #POFF in an IOU module generates a diagnostic. An informative error will be generated if label does not fall on the appropriate boundary. # The functions are: | #WOFF(label) | CPU or IOU | Returns the offset in words. | |--------------|------------|-----------------------------------| | #HOFF(label) | CPU only | Returns the offset in half-words. | | #P0FF(label) | CPU only | Returns the offset in parcels. | | #80FF(label) | CPU or IOU | Returns the offset in bytes. | 7.0 CYBER 180 CPU SYMBOLIC MACHINE INSTRUCTIONS ### 7.0 CYBER 180 CPU SYMBOLIC MACHINE INSTRUCTIONS The CYBER 180 Assembler recognizes symbolic notation for all CYBER 180 CPU Instructions. Instructions in this group are valid only for a MACHINE pseudo instruction type of C180CPU. If the MACHINE pseudo instruction type is C180IOU the mnemonics listed in this section will generate errors. The Assembler identifies each symbolic instruction according to its mnemonic. The object code for the instruction is generated in the block in use when the instruction is encountered. For a more complete description of the hardware instructions, refer to the CYBER 180 Processor-Memory Model-Independent GDS. #### 7.1 SYMBOLIC\_NOTATION This section describes notation used for coding symbolic CYBER 180 instructions. The CPU instructions are listed according to the CYBER 180 MIGDS Reference Numbers. The instruction descriptions are obtained from the CYBER 180 MIGDS. Lengths will always specify the actual number. The Assembler will make any adjustments necessary, as when the hardware requires the length to be entered as length-1. Any D or Q field that is adjusted by the Assembler will be denoted by the word label in the mnemonic description, and will then be further described as to exactly what the Assembler expects for that field. The label field of a symbolic machine instruction optionally contains a label. When the label is present, it is assigned the value of the byte offset after it is forced (if required) to parcel boundary. The symbol category of the label will be set to 6. The operation field of a symbolic machine instruction contains an instruction mnemonic and might also contain several other subfields. The argument field contains the instruction operands as one or more subfields. An optional comment field may appear following the last subfield of the argument field. A comment field must begin with a period (.) character. CYBER 180 II Assembler ERS 7.0 CYBER 180 CPU SYMBOLIC MACHINE INSTRUCTIONS 7.1 SYMBOLIC NOTATION The mnemonics chosen are descriptive of the actual hardware operation being performed and will provide for a high degree of recognition by the 2nd and 3rd reader of assembly language programs. In all cases, the mnemonics are 8 characters or less, and in most cases much less. This should provide for a certain ease in programming. The rules enforced when defining the instructions are: - o A common abbreviation used when shortening the mnemonics. - o The first part of the mnemonic describing the action to be performed. - o The second part of the mnemonic further qualifies the type of action to be taken (X used to represent a full X register, R for right half of an X register, BIT signifying operation on a bit field, etc.). - o The operand fields are written such that multiple subfields relating to source or destination are positioned together. - o Implied registers are written as part of required instruction syntax. - o The operands are written such that the most significant or resultant register is written first. #### 7.2 CPU INSTRUCTION FORMATS The figures in this section illustrate the formats for the CYBER 180 16-bit and 32-bit CPU instructions generated by the Assembler. For all instructions the Assembler generates parcel alignment whenever necessary. Figure 8.1 CYBER 180 ikiD Instruction Format CYBER 180 II Assembler ERS \*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\* 7.0 CYBER 180 CPU SYMBOLIC MACHINE INSTRUCTIONS 7.2 CPU INSTRUCTION FORMATS Figure 8.2 - CYBER 180 SikiD Instructions Format For these 32-bit instruction formats: the j, k, and i fields provide register designations, the D field provide either a signed shift count, a positive displacement or a bit-string descriptor, and the S field provide a sub-operation code. Figure 8.3 - CYBER 180 jk Instruction: Format For this 16-bit instruction: format, the j field provides a register designation, a sub-operation code, or an immediate operand value and the k field provides a register designation. Figure 8.4 - CYBER 180 jkQ Instruction Format For this 32-bit instruction format, the j and k fields provide register designations or sub-operation codes. The 16-bit Q-field provides a signed displacement or an immediate operand value. #### 7.3 GENERAL CPU INSTRUCTIONS The CYBER 180 Assembler's CPU Instructions Group is subdivided into the following classes of instructions according to function. #### 7.3.1 LOAD AND STORE This sub-group of instructions shall provide the means for transferring data, in the form of a single bit, a byte string, a 64-bit word, or multiple 64-bit words between one or more Registers and one or more locations in central memory as specified by the individual instruction mnemonic. #### CYBER 180 II Assembler ERS 7.0 CYBER 180 CPU SYMBOLIC MACHINE INSTRUCTIONS 7.3.1 LOAD AND STORE For the purpose of establishing operand access validity for the associated central memory read and write accesses, the ring number used for validation is the value of the ring number contained in bit positions 16 through 19 of the associated A Register. The central memory operand access type is read-access for any instruction which loads an A or X register, and write-access for any instruction which stores an A or X register. Instructions which transfer data from one or more Registers to central memory, (namely, Store instructions), do not alter the contents of any Register which serves as a source of the data to be transferred to central memory. ### 7.3.1.1 LBYIS.SBYIS-Load/Store Bytes. Xk Length Per S a) Load Bytes to Xk from (Aj) displaced by D and indexed by (Xi) Right, Length Per S. LBYTS - (Format = SjkiD Op Code = DO-D7 Ref# = 001) | + | <b>4</b> | <u> </u> | |---|-----------|----------| | | operation | argument | | • | ILBYTS,S | | S - number of bytes to load(1-8). b) Store Bytes from Xk at (Aj) displaced by D and indexed by (Xi) Right, Length per S. SBYTS - (Format = SikiD Op Code = D8-DF Ref# = 003) | + | _+ | + | |---|-----------|----------| | • | operation | argument | | 1 | ISBYTS,S | • | S - number of bytes to store(1-8). 86/10/17 CYBER 180 II Assembler ERS Rev: F 7.0 CYBER 180 CPU SYMBOLIC MACHINE INSTRUCTIONS 7.3.1.2 LYI.LY.SYI.SY+Load/Store Words Yk 7.3.1.2 LXI,LX,SXI,SX-Load/Store Word, Xk #### 7.3.1.2 LXI.LX.SXI.SX-Load/Store Word. Xk a) Load Xk from (Aj) displaced by 8\*D and indexed by 8\*(Xi) Right. LXI - (Format = jkiD Op Code = A2 Ref# = 005) | + | + | | |--------|-----------|---------------------------------------| | llabel | operation | largument | | | • | · · · · · · · · · · · · · · · · · · · | | 1 | ILXI | Xk,Aj,Xi,label | label - byte address, must be on a word boundary. b) Load Xk from (Aj) displaced by 8\*Q. LX - (Format = jkQ Op Code = 82 Ref# = 006) | + | + | | |---|-----------|-------------| | | operation | · 'W | | 1 | 7 | Xk,Aj,label | label - byte address, must be on a word boundary. c) Store Xk at (Aj) displaced by 8\*D and indexed by 8\*(Xi) Right. SXI - (Format = jkiD Op Code = A3 Ref# = 007) label: - byte address, must be on a word boundary. ### CYBER 180 II Assembler ERS 7.0 CYBER 180 CPU SYMBOLIC MACHINE INSTRUCTIONS 7.3.1.2 LXI,LX,SXI,SX-Load/Store Word, Xk - d) Store Xk at (Aj) displaced by 8‡Q. - SX (Format = jkQ Op Code = 83 Ref# = 008) | + | + | | |---|------------|--------------| | | loperation | largument | | 1 | ~ | lXk,Aj,label | label - byte address, must be on a word boundary. ### 7.3.1.3 LBYI.SBYI-Load/Store Bytes. Xk Length Per XQ a) Load Bytes to Xk from (Aj) displaced by D and indexed by (Xi) Right, Length per XO. LBYT - (Format = jkiD Op Code = A4 Ref# = 009) | + | + | + | |---|------------|------------| | | loperation | largument | | i | * | Xk,Aj,Xi,D | Store Bytes from Xk at (Aj) displaced by D and indexed by (Xi) Right, Length per XO. SBYT - (Format = jkiD Op Code = A5 Ref# = 011) | + | | <b>.</b> | |---|-----------|----------| | | operation | argument | | 1 | SBYT,XO | * | #### CYBER 180 II Assembler ERS 7.0 CYBER 180 CPU SYMBOLIC MACHINE INSTRUCTIONS 7.3.1.4 LBYTP-Load Bytes, Xk Length per j - 7.3.1.4 LBYIP-Load Bytes. Xk Length per i - a) Load Bytes to Xk from (P) displaced by Q, Length per j. LBYTP - (Format = jkQ Op Code = 86 Ref# = 013) label: - byte address of the data. j - number of bytes to load(1-8). - 7.3.1.5 LBII.SBII-Load/Store Bit. Xk - a) Load Bit to Xk (Aj) displaced by Q and bit indexed by (XO) Right. LBIT - (Format = $jkQ \Omega p Code = 88 Ref# = 014$ ) b) Store Bit from Xk at (Aj) displaced by Q and bit indexed by (XO) Right. SBIT - (Format = jkQ Op Code = 89 Ref# = 015) | + | -+ | + | |---|------------|-----------| | | loperation | largument | | 1 | 18817 | | - 7.3.1.6 LAI.LA.SAI.SA-Load/Store.Ak - a) Load Ak from (Aj) displaced by D and Indexed by (Xi) Right. LAI - (Format = ikiD Op Code = AO Ref# = 016) #### CYBER 180 II Assembler ERS 7.0 CYBER 180 CPU SYMBOLIC MACHINE INSTRUCTIONS 7.3.1.6 LAI,LA,SAI,SA-Load/Store,Ak | label | loperation | argument | label | lak, Aj, Xi, D - b) Load Ak from (Aj) displaced by Q. - LA (Format = jkQ Op Code = 84 Ref# = 017) - c) Store Ak at (Aj) displaced by D and indexed by (Xi) Right. - SAI (Format = jkiD Op Code = A1 Ref# = 018) - d) Store Ak at (Aj) displaced by Q. - SA (Format = jkQ Op Code = 85 Ref# = 019) #### CYBER 180 II Assembler ERS 7.0 CYBER 180 CPU SYMBOLIC MACHINE INSTRUCTIONS 7.3.1.7 LMULT, SMULT-Load/Store Multiple Registers ### 7.3.1.7 LMULI-SMULI-Load/Store Multiple Registers a) Load Multiple Registers from (Aj) displaced by 8\*Q, Selectivity per (Xk) Right. LMULT - (Format = ikQ Op Code = 80 Ref# = 020) | + | + | + | |---|------------|-------------| | | loperation | 100 | | + | + | + | | 1 | LMULT | Xk,Aj,label | label - byte address, must be on a word boundary **b**) Store Multiple Registers at (Aj) displaced by 8#Q, Selectivity per (Xk) Right. SMULT - (Format = jkQ Op Code = 81 Ref# = 021) ``` llabel | | loperation | largument ISMULT |Xk,Aj,label ``` label - byte address, must be on a word boundary #### 7.3.2 INTEGER ARITHMETIC Integer arithmetic operations shall be performed on words and halfwords contained in Register Xk and Register Xk Right, respectively, as described in the following subparagraphs. Binary integers contained in the X Registers consist of signed, two's complement, 32-bit or 64-bit quantities. The leftmost bit, (in position 00 for 64-bit integers and in position 32 for 32-bit integers), constitute the sign bit. The ranges in magnitude, M, covered by binary integers in each of the two fixed point formats, are the following: 32-bit Integer: $-2(31) \le M \le 2(31)-1$ 64-bit Integer: $-2(63) \le M \le 2(63) - 1$ #### CYBER 180 II Assembler ERS 7.0 CYBER 180 CPU SYMBOLIC MACHINE INSTRUCTIONS 7.3.2.1 ADDX, ADDXQ, INCX-Integer Sum, Xk #### 7.3.2.1 ADDX.ADDXQ.INCX-Integer\_Sum. Xk Integer Sum, (Xk) replaced by (Xk) plus (Xj). ADDX - (Format = jk Op Code = 24 Ref# = 022) loperation largument ADDX IXk,Xi Integer Sum, (Xk) replaced by (Xj) plus Q. **b**) ADDXQ - (Format = $jkQ \Omega p Code = 88 Ref# = 143)$ llabel loperation largument IADDXQ IXk,Xj,Q Integer Sum, (Xk) replaced by (Xk) plus i. INCX - (Format = jk Op Code = 10 Ref# = 166) label loperation largument INCX IXk, i # 7.3.2.2 SUBX.DECX-Integer\_Difference. Xk Integer Difference, (Xk) replaced by (Xk) minus (Xj). SUBX - (Format = jk Op Code = 25 Ref# = 023) llabel loperation largument SUBX IXk,Xi # CYBER 180 II Assembler ERS 7.0 CYBER 180 CPU SYMBOLIC MACHINE INSTRUCTIONS 7.3.2.2 SUBX, DECX-Integer Difference, Xk 7.3.2.2 SUBX, DECX-Integer Difference, XK b) Integer Difference, (Xk) replaced by (Xk) minus j. DECX - (Format = jk Op Code = 11 Ref# = 167) | • | • | • | |---|------------|----------| | | loperation | argument | | • | DECX | | 7.3.2.3 MULX.MULXQ-Integer Product. Xk a) Integer Product, (Xk) replaced by (Xk) times (Xj). MULX - (Format = jk Dp Code = 26 Ref# = 024) | + | + | <del> </del> | |---|-----------|--------------| | | operation | largument | | • | MULX | • | b) Integer Product, (Xk) replaced by (Xi) times Q. MULXQ - (Format = jkQ Op Code = B2 Ref# = 168) | + | + | | |---|-----------|--------------| | | operation | | | | MULXQ | +<br> Xk, X | 7.3.2.4 DIVX-Integer\_Quotient a) Integer Quotient, (Xk) replaced by (Xk) divided by (Xj). DIVX - (Format = jk Op Code = 27 Ref# = 025) | + | + | + | |---|------------|----------| | | loperation | argument | | • | IDIVX | • | # CYBER 180 II Assembler ERS 7.0 CYBER 180 CPU SYMBOLIC MACHINE INSTRUCTIONS 7.3.2.5 ADDR, ADDRQ, INCR-Integer Sum, Xk right # 7.3.2.5 ADDR.ADDRQ.INCR-Integer\_Sum. Xk right a) Integer Sum, (Xk) Right replaced by: (Xk) Right plus (Xj) Right. ADDR - (Format = jk Op Code = 20 Ref# = 027) | + | + | <b>+</b> | |---|------------|-----------------| | | loperation | • | | • | ADDR | +<br> Xk , X j | b) Integer Sum, (Xk) Right replaced by (Xj) Right plus Q. ADDRQ - (Format = jkQ Op Code = 8A Ref# = 028) | + | + | | |---|-----------|----------| | | operation | argument | | • | ADDRQ | | c) Integer Sum, (Xk) Right replaced by (Xk) Right plus j. INCR - (Format = ik Op Code = 28 Ref# = 029) | + | + | | |---|------------|----------| | | loperation | argument | | • | INCR | • | # 7.3.2.6 SUBR.DECR-Integer\_Difference.Xk Right a) Integer Difference, (Xk) Right replaced by (Xk) Right minus (Xj) Right. SUBR - (Format = jk Op Code = 21 Ref# = 030) | + | + | | |---|------------|----------| | | loperation | argument | | 1 | • | [Xk,Xj | | CYRER | 180 | TI | Assemb | ler | FRS | |-------|-----|----|--------|-----|-----| | | | | | | | 7.0 CYBER 180 CPU SYMBOLIC MACHINE INSTRUCTIONS 7.3.2.6 SUBR, DECR-Integer Difference, Xk Right b) Integer Difference, (Xk) Right replaced by (Xk) Right minus j. DECR - (Format = jk Op Code = 29 Ref# = 031) ### 7.3.2.7 MULR.MULRO-Integer Product. Xk Right a) Integer Product, (Xk) Right replaced by (Xk) Right times (Xj) Right. MULR - (Format = jk Op Code = 22 Ref# = 032) | 4 | + | <b>,</b> | |---|------------|----------| | | loperation | argument | | • | MULR | • | b) Integer Product, (Xk) Right replaced by (Xi) Right times Q. MULRQ - (Format = jkQ Op Code = 8C Ref# = 033) | + | + | + | |---|------------|----------| | | loperation | argument | | • | IMULRQ | • | #### 7.3.2.8 DIVR-Integer Quotient. Xk Right a) Integer Quotient, (Xk) Right replaced by (Xk) Right divided by (Xj) Right. DIVR - (Format = jk Op Code = 23 Ref# = 034) | + | | | |---|-----------|-----------| | | operation | largument | | 1 | DIVR | • | #### CYBER 180 II Assembler ERS 7.0 CYBER 180 CPU SYMBOLIC MACHINE INSTRUCTIONS 7.3.2.9 CMPX, CMPR-Integer Compare 7.3.2.9 CMPX.CMPR-Integer\_Compare a) Integer Compare (Xj) to (Xk), result to X1 Right. CMPX - (Format = jk Op Code = 2D Ref# = 035) | + | + | <del>*</del> | |--------|------------|----------------------------------------------------------------------------------------------------------------| | llabel | loperation | largument en la companya de la companya de la companya de la companya de la companya de la companya de la comp | | + | + | <del></del> | | 1 | I CMPX | IX1,Xj,Xk | b) Integer Compare (Xi) Right to (Xk) Right, result to X1 Right. CMPR - (Format = jk Op Code = 2C Ref# = 036) 7.3.3 BRANCH The instructions within this subgroup consist of both conditional and unconditional branch instructions. Each conditional branch instruction performs a comparison between the contents of two general registers. Then, based on the relationship between the results of that comparison and the branch condition as specified by means of the instruction's operation code, each conditional branch instruction performs either a normal exit or a branch exit. Normal exit: When the results of a comparison do not satisfy the branch condition as specified by the operation code, a normal exit is performed. A normal exit for all conditional branch instructions consists of adding four to the rightmost 32 bits of the PVA obtained from the P Register, with that 32-bit sum returned to the P Register in its rightmost 32-bit positions. Branch exit: When the results of a comparison satisfy the branch condition as specified by the operation code, a branch exit is performed. A branch exit consists of expanding the 16-bit Q field from the instruction to 31 bits by means of sign extension, shifting these 31 bits left one bit position with a zero inserted on the right, and adding this 32-bit shifted result #### CYBER 180 II Assembler ERS 7.0 CYBER 180 CPU SYMBOLIC MACHINE INSTRUCTIONS 7.3.3 BRANCH to the rightmost 32-bits of the PVA obtained from the P Register, with the 32-bit sum returned to the P Register in its rightmost 32-bit positions. Unconditional branch instructions perform branch exits according to the appropriate instruction descriptions contained in subparagraphs 2.2.3.5 and 2.2.3.6 of the MIGDS. The Assembler sets the instruction's Q field according to the value of the 'label' subfield of the instruction mnemonics, which must correspond to a label of an Assembler statement within the currently active section. Relative addresses cannot span section boundaries. ### 7.3.3.1 BRXEQ.BRXNE.BRXGI.BRXGE-Branch Conditional a) Branch to (P) displaced by 2\*Q if (Xj) equal to (Xk). BRXEQ - (Format = jkQ Op Code = 94 Ref# = 037) | + | + | + | |--------|-----------|-------------| | llabel | operation | largument | | | , | · | | • | | Xj,Xk,label | label - byte address of the new location. b) Branch to (P) displaced by 2\*Q if (Xj) not equal to (Xk). BRXNE - (Format = jkQ Op Code = 95 Ref# = 038) | + | + | | |---|-----------|-------------| | • | operation | largument | | 1 | • | Xi,Xk,label | label - byte address of the new location. ### CYBER 180 II Assembler ERS 7.0 CYBER 180 CPU SYMBOLIC MACHINE INSTRUCTIONS 7.3.3.1 BRXEQ, BRXNE, BRXGT, BRXGE-Branch Conditional Branch to (P) displaced by 2\*Q if (Xi) greater than (Xk). c) BRXGT - (Format = jkQ Op Code = 96 Ref# = 039) | + | | | |---|------------|-------------| | | loperation | argument | | • | • | Xj,Xk,label | label - byte address of the new location. Branch to (P) displaced by 2\*Q if (Xj) greater than or equal to (Xk). BRXGE - (Format = jkQ Op Code = 97 Ref# = 040) label - byte address of the new location. # 7.3.3.2 BRREQ.BRRNE.BRRGI.BRRGE-Conditional. X Right Branch to (P) displaced by 2\*Q if (Xj) Right equal to (Xk) a) Right. BRREQ - (Format = jkQ Op Code = 90 Ref# = 041) label - byte address of the new location. #### CYBER 180 II Assembler ERS CIREN TOO II WOOCHILE FUO 7.0 CYBER 180 CPU SYMBOLIC MACHINE INSTRUCTIONS 7.3.3.2 BRREQ, BRRNE, BRRGT, BRRGE-Conditional, X Right 7.3.3.2 BKKEQ, BKKNE, BKKGI, BKKGE-Conditional, X Kight b) Branch to (P) displaced by 2\*Q if (Xj) Right not equal to (Xk) Right. BRRNE - (Format = jkQ Op Code = 91 Ref# = 042) | + | + | | |---|------------|-------------| | • | loperation | argument | | • | * | Xj,Xk,label | label - byte address of the new location. c) Branch to (P) displaced by 2\*Q if (Xj) Right greater than (Xk) Right. BRRGT - (Format = jkQ Dp Code = 92 Ref# = 043) label - byte address of the new location. d) Branch to (P) displaced by 2≠Q if (Xj) Right greater than or equal to (Xk) Right. BRRGE - (Format = jkQ Op Code = 93 Ref# = 044) label - byte address of the new location. ### CYBER 180 II Assembler ERS 7.0 CYBER 180 CPU SYMBOLIC MACHINE INSTRUCTIONS 7.3.3.3 BRING-Conditional, with Increment 7.5.5.5 DRING-CONDICIONAL, WITH INCREMENT #### 7.3.3.3 BRING-Conditional with Increment a) Branch to (P) displaced by 2\*Q and increment (Xk) if (Xj) greater than (Xk). BRINC - (Format = jkQ Op Code = 9C Ref# = 045) label - byte address of the new location. ### 7.3.3.4 BRSEG-Conditional. Ak a) Branch to (P) displaced by 2\*Q if SEG(Aj) not equal to SEG(Ak); else Compare BN(Aj) to BN(Ak), result to X1 Right. BRSEG - (Format = jkQ Op Code = 9D Ref# = 046) | + | <del>+</del> | <del>-</del> | |---|--------------|----------------| | | loperation | argument | | * | * | X1,Aj,Ak,label | label - byte address of the new location. # 7.3.3.5 BRREL-Unconditional Branch. (P) indexed a) Branch to (P) indexed by 2\*(Xk) Right. 8RREL - (Format = jk Op Code = 2E Ref# = 047) | llabel | loperation | largument | |--------|------------|-----------| | • | BRREL | | #### CYBER 180 II Assembler ERS 7.0 CYBER 180 CPU SYMBOLIC MACHINE INSTRUCTIONS 7.3.3.6 BRDIR-Unconditional Branch, (A) indexed #### 7.3.3.6 BRDIR-Unconditional Branch. (A) indexed a) Branch to (Aj) indexed by 2\*(Xk) Right. BRDIR - (Format = jk Op Code = 2F Ref# = 048) | label | loperation | argument | BRDIR | laj,Xk • • • • • • 7.3.4 COPY The instructions within this subgroup provide the means for accomplishing inter-register transfers to the extent defined by the following instruction descriptions. # 7.3.4.1 CPYXX-Copy\_to\_Xk\_from\_Xj CPYXX - (Format = ik Op Code = OD Ref# = 049) # 7.3.4.2 CPYAX-Copy\_to\_Xk\_from\_Ai CPYAX - (Format = $ik \Omega p$ Code = 08 Ref# = 050) ### CYBER 180 II Assembler ERS 7.0 CYBER 180 CPU SYMBOLIC MACHINE INSTRUCTIONS 7.3.4.3 CPYAA-Copy to Ak from Aj 1.5.4.5 CPTAATCOPY. CO AK ITOM AJ ### 7.3.4.3 CPYAA-Copy to Ak from Aj CPYAA - (Format = jk Op Code = 09 Ref# = 051) #### 7.3.4.4 CPYXA-Copy to Ak from Xi CPYXA - (Format = jk Op Code = OA Ref# = 052) # 7.3.4.5 CPYRR-Copy to Xk Right from Xj Right CPYRR - (Format = jk Op Code = OC Ref# = 053) 7.3.5 ADDRESS ARITHMETIC The instructions within this subgroup shall provide the means for accomplishing address arithmetic to the extent defined by the following instruction descriptions. #### CYBER 180 II Assembler ERS 7.0 CYBER 180 CPU SYMBOLIC MACHINE INSTRUCTIONS 7.3.5.1 ADDAQ-Copy A with Displacement # 7.3.5.1 ADDAQ-Copy A with Displacement a) Address (Ak) replaced by (Aj) plus Q. ADDAQ - (Format = jkQ Op Code = 8E Ref# = 054) | + | | . 4 | |---|------------|-----------| | | loperation | largument | | 1 | IADDAQ | • | # 7.3.5.2 ADDPXQ-Copy P with Indexing and Displacement a) Address (Ak) replaced by (P) plus 2\*(Xj) Right plus 2\*Q. ADDPXQ - (Format = jkQ Op Code = 8F Ref# = 055) | + | + | | |---|------------|-------------| | | loperation | largument | | • | • | Ak,Xj,label | label - byte address of the new location. # 7.3.5.3 ADDAX=A\_Indexed a) Address (Ak) replaced by (Ak) plus (Xj) Right. ADDAX - (Format = jk Op Code = 2A Ref# = 056) | llabel | operation | argument | |--------|-----------|----------| | * | ADDAX | • | 86/10/17 | CYBER | 180 | TT | Accon | hlar | EDC | |-------|-----|----|-------|-------|---------| | LIDER | 101 | 11 | ASSE | m ier | _ C X 3 | Rev: F 7.0 CYBER 180 CPU SYMBOLIC MACHINE INSTRUCTIONS 7.3.5.4 ADDAD-Copy A with Displacement, Modulo. # 7.3.5.4 ADDAD-Copy A with Displacement. Modulo a) Address (Ak) replaced by (Ai) plus D per j. ADDAD - (Format = jkiD Op Code = A7 Ref# = 161) loperation largument LADDAD lak, Ai, D, j 7.3.6 ENTER The instructions within this subgroup provide the means for entering immediate operands, (consisting of logical quantities of signed, two's complement binary integers), into the X Registers to the extent defined by the following instruction descriptions. #### 7.3.6.1 ENIP.ENIN-Enter\_i a) Enter Xk with plus j. ENTP - (Format = jk Op Code = 3D Ref# = 057) | - | | + | |-----|-----------|------------| | · · | operation | 125 | | • | ENTP | t<br>!xk.i | | 3 | 1 | 3 A A Y 3 | b) Enter Xk with minus j. ENTN - (Format = ik Op Code = 3E Ref# = 058) loperation largument llabel LENTN IXk, i CYBER 180 II Assembler ERS Rev: F 7.0 CYBER 180 CPU SYMBOLIC MACHINE INSTRUCTIONS 7.3.6.2 ENIE-Enter\_Q 7.3.6.2 ENTE-Enter Q a) Enter Xk with sign extended Q. ENTE - (Format = jkQ Op Code = 8D Ref# = 059) | + | + | | |---|------------|-----------| | | loperation | largument | | * | IENTE | • | 7.3.6.3 ENIL-ENIX-Enter\_jk a) Enter XO with logical ik. ENTL - (Format = jk Op Code = 3F Ref# = 060) | label | loperation | 366 | |-------|------------|---------| | • | ENTL | 1X0, jk | b) Enter X1 with logical jk. ENTX - (Format = $jk \ \Box p \ Code = 39 \ Ref# = 164$ ) | 1 | label | operation | argument | |---|-------|-----------|----------| | 1 | | ENTX | * | #### CYBER 180 II Assembler ERS 7.0 CYBER 180 CPU SYMBOLIC MACHINE INSTRUCTIONS 7.3.6.4 ENTZ, ENTQ, ENTS-Enter Signs ### 7.3.6.4 ENIZ.ENIQ.ENIS-Enter Signs Enter Xk Left with signs per j. The value of the right most 2-bits of the j field from the instruction shall be translated as follows: If 00, 32 bit positions of Xk Left shall be cleared (zeroes). If 01, 32 bit positions of Xk Left shall be set (ones). If 10 or 11, 32 bit positions of Xk Left shall be set to the value of the sign bit in position 32 of Xk Right. ENTZ - (Format = jk Dp Code = 1F Ref# = 061) ENTO - (Format = ik Op Code = 1F Ref# = 061) ENTS - (Format = jk Op Code = 1F Ref# = 061) | + | | | |--------|-----------------------------------------|----------| | llabel | * * * * * * * * * * * * * * * * * * * * | argument | | [ | IENTZ | 1 | | I | IENTO | l Xk | | • | <b>IENTS</b> | 1 | The assembler computes the value of j from the specific instruction mnemonic used. # 7.3.6.5 ENIC-Enter\_X1\_jkQ a) Enter X1 with sign extended jkQ. ENTC - (Format = jkQ Op Code = 87 Ref# = 165) | + | -+ | + | |---|------------|-----------| | | loperation | largument | | | IENTC | • | CYBER 180 II Assembler ERS 7.0 CYBER 180 CPU SYMBOLIC MACHINE INSTRUCTIONS 7.3.6.6 ENTA-Enter XO ikQ reserve this thich to just # 7.3.6.6 ENIA-Enter XO ikQ a) Enter XO with sign extended jkQ. ENTA - (Format = jkQ Op Code = 83 Ref# = 169) | llabel | operation | argument | | |--------|-----------|----------|---| | • | | lxo,jkQ | _ | 7.3.7 SHIFT The instructions within this subgroup provided the means for shifting the initial contents of the Xj Register and transferring the result to the Xk Register, to the extent defined by the following descriptions. All of the instructions within this subgroup derive the computed shift count in the following manner: The rightmost 8 bits of the D field from the instruction is added to the rightmost 8 bits initially contained in bit positions 56 through 63 of Register Xi Right and the 8-bit sum represents the computed shift count. Any overflow from the 8-bit sum is ignored. In this context, the contents of Register XO Right are interpreted as consisting entirely of zeroes. The instructions within this subgroup shall interpret the computed shift count as follows: The sign-bit in the leftmost position of the 8-bit computed shift count shall determine the direction of the shift. When the computed shift count is positive (sign bit of zero), these instructions shall left shift. When the computed shift count is negative (sign-bit of one), these instructions shall right shift. For 32-bit quantities, shifts shall be from 0-31 bits left and from 1-32 bits right. For 64-bit quantities, shifts shall be from 0-63 bits left and from 1-64 bits right. When these interpretations of the computed shift count result in an actual shift count of zero, the associated instructions transfer the initial contents of the Xj Register to the Xk Register and no shifting is performed. #### CYBER 180 II Assembler ERS 7.0 CYBER 180 CPU SYMBOLIC MACHINE INSTRUCTIONS 7.3.7.1 SHFC-Shift (Xj) to Xk, Circular # 7.3.7.1 SHEC-Shift (Xi) to Xk. Circular a) Shift (Xj) to Xk Circular, Direction and Count per (Xi) Right plus D. SHFC - (Format = jkiD Op Code = A8 Ref# = 062) | + | | <del> </del> | |--------|---|--------------| | llabel | * | largument | | • | · | IXk,Xj,Xi,D | # 7.3.7.2 SHEX.SHER-Shift (Xj) to Xk. End-Off a) Shift (Xj) to Xk, Direction and Count per (Xi) Right plus D. SHFX - (Format = jkiD Op Code = A9 Ref# = 063) | llabel | loperation | t | |--------|------------|---| | - | ISHFX | • | b) Shift (Xj) Right to Xk Right, Direction and Count per (Xi) Right plus D. SHFR - (Format = jkiD Op Code = AA Ref# = 064) | + | + | | |---|-----------|----------| | | operation | argument | | • | SHFR | • | . ..... . CYBER 180 II Assembler ERS 7.0 CYBER 180 CPU SYMBOLIC MACHINE INSTRUCTIONS 7.5.8 LUGICAL 7.3.8 LOGICAL The instructions within this subgroup shall provide the means for performing Boolean operations on the 64-bit words contained in the X Registers to the extent defined by the following instruction descriptions. 7.3.8.1 IORX.XORX.ANDX-Logical Sum. Diff. and Prod. a) Logical Sum (Xk) replaced by (Xk) OR (Xj). IORX - (Format = jk Op Code = 18 Ref# = 065) | + | <del> </del> | <del>+</del> | |--------|--------------|--------------| | llabel | . , | largument | | - | IORX | • | b) Logical Difference, (Xk) replaced by (Xk) EOR (Xj). XORX - (Format = jk Op Code = 19 Ref# = 066) | + | _+ | + | |---|------------|-----------| | | loperation | largument | | 1 | IXORX | • | c) Logical Product, (Xk) replaced by (Xk) AND (Xj). ANDX - (Format = jk'Dp Code = 1A Ref# = 067) | + | + | <del>-</del> | |---|------------|--------------| | | loperation | largument | | • | IANDX | • | #### CYBER 180 II Assembler ERS CIDEK TOO IT WASHINGTON EKA 7.0 CYBER 180 CPU SYMBOLIC MACHINE INSTRUCTIONS 7.3.8.2 NOTX-Logical Complement 7.3.8.2 NOIX-Logical Complement a) Logical Complement, (Xk) replaced by (Xj) NOT. NOTX - (Format = jk Op Code = 1B Ref# = 068) | + | + | + | |---|------------|--------| | | operation. | | | • | INOTX | txk,xj | # 7.3.8.3 INHX-Logical Inhibit a) Logical Inhibit, (Xk) replaced by (Xk) AND (Xi) NDT INHX - (Format = jk Op Code = 1C Ref# = 069) 7.3.9 REGISTER BIT STRING The instructions within this subgroup provide the means for addressing a contiguous string (field) of bits, beginning and ending independently with any bit positions within a 64-bit word. For each of these instructions in this subgroup, the bit string is addressed by means of a 12-bit field referred to as a bit string descriptor. Any field of bits, including the field constituting a bit field descriptor, is numbered from left to right, with the leftmost bit numbered 00. The six-bit subfield in bit positions 00 through 05 of a bit string descriptor designates the beginning, or leftmost, bit position within a 64-bit word. The 6-bit subfield in bit positions 06 through 11 of the bit string descriptor is a length designator that is interpreted as designating one less than the length (in bits) of a bit string within a 64-bit word. #### CYBER 180 II Assembler ERS 7.0 CYBER 180 CPU SYMBOLIC MACHINE INSTRUCTIONS 7.3.9 REGISTER BIT STRING Bit String Descriptor | 10 | | 11 | |---------|------------------------------|----------------| | i | Leftmost Position Designator | · | | <b></b> | | (Bit Length-1) | For all instructions within this subgroup, indexing is carried out as follows: the bit string descriptor obtained from the D field of the instruction is zero-extended on the left to 32 bits and then added, without overflow detection, to the contents of register Xi Right (in this context, the contents of register XO shall be interpreted as all zeroes); the rightmost 12 bits of the result is then interpreted as a bit string descriptor, in the manner described above. #### 7.3.9.1 ISOM-Isolate\_Bit\_Mask a) Isolate Bit Mask into Xk per (Xi) Right plus D. ISOM - (Format = ikiD Op Code = AC Ref# = 070) | + | + | + | |---|------------|----------| | | loperation | argument | | * | IISOM | • | #### 7.3.9.2 ISOB-Isolate\_into\_Xk a) Isolate into Xk from Xj per (Xi) Right plus D. ISOB - (Format = jkiD Op Code = AD Ref# = 071) | <b>+</b> | | + | |----------|-----------|-------------| | | operation | | | 1 | 11508 | 1Xk,Xi,Xi,D | 86/10/17 ## CYBER 180 II Assembler ERS Rev: F 7.0 CYBER 180 CPU SYMBOLIC MACHINE INSTRUCTIONS 7.3.9.3 INSB-Insert into Xk 7.3.9.3 INS8-Insert\_into\_Xk Insert into Xk from Xj per(Xi) Right plus D. INSB - (Format = jkiD Op Code = AE Ref# = 072) | + | + | <del></del> | |---|-----------|-------------| | | operation | largument | | | | • | 7.3.10 MARK-MARK TO BOOLEAN This instruction tests the two bits initially contained in the leftmost two bit positions, 32 and 33, of Register X1 Right according to the 4-bit j field from the instruction. When the value of the two leftmost bits initially contained in Register XI Right is equal to any of the one or more values specified by the instruction's j field, Register Xk shall be cleared in bit positions 1 through 63 and set in bit position 0. When the value of the two leftmost bits initially contained in Register X1 Right is not equal to any of the one or more values specified by: the instruction's j field, Register Xk Right is cleared in all 64 bit positions, 0 through 63. 7.0 CYBER 180 CPU SYMBOLIC MACHINE INSTRUCTIONS 7.3.10 MARK-MARK TO BOOLEAN entropental number to communicate de la del communicate de la communicat The values of the j field and the leftmost two bits initially contained in Register X1 Right shall be interpreted with respect to equality (EQ) as follows: | <b>j</b> | Binary | Value o<br>00 | f Bits | 32 and 3 | 3 of X1 | Right,<br>10 | respecti | vely<br>11 | |----------|-------------------------------------|-----------------------------------------|----------|-----------|---------|--------------|----------|------------| | 100001 | | *************************************** | t<br>Un | condition | al ineq | uality | | | | 0001 | - 160 - 160 - 160 - 160 - 160 - 160 | 10 dan 110 dan 110 dan 110 dan 110 | ! | | ! | | | EQ | | 0010 | | | ! | | 1 | EQ | ! | | | 0011 | | | ! | | 1 | EQ | 1 | EQ | | 0100 | | | | EQ | ! | | | | | 0101 | | | | EQ | | | | EQ | | 0110 | | | <u> </u> | EQ | 1 | EQ | | | | 0111 | | | | EQ | 1 | EQ | | EQ | | 11000 | | EQ | | | | | 1 | | | 1001 | | EQ | | | i | | | EQ | | 1010 | | EQ. | | | İ | EQ | | | | 1011 | | EQ | | | İ | EQ | | EQ | | 11100 | | EQ | | EQ | | | | | | 11101 | | EQ | | EQ | | | | EQ | | 11110 | | EQ | | EQ | | EQ | İ | | | 11111 | | | U | nconditio | nal Equ | ality | | | | 1111 | | | | ^ | | <u> </u> | | ^ | | +++- | | T | | +<br> | | | | 1 | | +* | | | | | | | | ,<br>-+ | The four individual bits of j can be visualized as individual pointers which are associated, from left to right, with the four possible values (00,01,10,11) of the tested bit-pair (bits 32 and 86/10/17 ### CYBER 180 II Assembler ERS Rev: F 7.0 CYBER 180 CPU SYMBOLIC MACHINE INSTRUCTIONS 7.3.10 MARK-MARK TO BOOLEAN 33 of Register X1 Right). For example, if j = 0101, equality is detected when the value of the tested bit pair is 01 or 11. a) Set Xk per j and (X1) Right. MARK - (Format = jk Op Code = 1E Ref# = 145) | + | + | + | |--------|------------|-------------| | llabel | loperation | largument | | + | + | <del></del> | | 1 | MARK | 1Xk,X1,j | 7.4 BUSINESS\_DATA\_PROCESSING\_INSTRUCTIONS The general form of execution for this group shall involve the utilization of a first data field in central memory, referred to as the "source", to modify, replace, or compare with a second data field in central memory referred to as the "destination". Both the source and destination fields shall be individually described by means of independently designated Data Descriptors, with respect to the types of representation, sign and zone conventions, lengths and relative locations of the data fields. The Data Descriptors shall be obtained from central memory: at locations immediately following the BDP instruction, as defined by the BDP instruction format and number of descriptors used by the instruction. All descriptors consist of a 32-bit half word, aligned to a parcel (16 bit) boundary in central memory. #### 7.4.1 GENERAL DESCRIPTION The instructions of this group utilize the jk and jkiD instruction formats in combination with one or two descriptors in the following combinations: 1) jk and two descriptors. | | * | Code | | J | | ** | | |---|------|------|---|---|---|----|---| | | + | | - | | - | | • | | Ρ | <br> | | | | | | | 7 | CYBER | 180 | 11 | Assem | ıb ler | ERS | | 86/10/1<br>Re <b>v:</b> F | |-------|------|-----|-------|--------|------|--------------|---------------------------| | | YBER | 180 | CPU | SYMBI | DLIC | INSTRUCTIONS | <br> | CYBER 180 II Assembler ERS 7.0 CYBER 180 CPU SYMBOLIC MACHINE INSTRUCTIONS 7.4.1.1 Operation Codes ## 7.4.1.1 Operation Codes A total of 18 operation codes shall be utilized by the instructions comprising the BDP Instruction group. For the purpose of this specification, the BDP Instruction group shall be further divided into four subgroups, including "short" instruction names, as follows: NOTE: For the order of exception sensing for these instructions, as well as all other instructions, refer to the CYBER 180 Processor-Memory Model-Independent GDS. | Subgroup | Short Name | |----------------|-----------------------------------------------------------------------------| | BDP Numeric | Sum Difference Product Quotient Scale Scale Rounded Decimal Compare Numeric | | Byte | Compare Compare Collated Scan While Non-Member Translate Move Bytes Edit | | Subscript | Calculate Subscript | | Immediate Data | Move Immediate Data<br>Compare Immediate Data<br>Add Immediate Data | ## 7.4.2 DATA DESCRIPTORS CYBER 180 II Assembler ERS 7.0 CYBER 180 CPU SYMBOLIC MACHINE INSTRUCTIONS 7.4.2 DATA DESCRIPTORS The generated Data Descriptor shall be formatted as follows: When specifying the data descriptor, the D field is not specified. The format for the source descriptor (SD) and the destination descriptor (DD) is the same, and is specified as F,T,L,D. - F 1 bit field specifier for length - T 4 bits data types - L 8 bits optional length field - 0 16 bits offset address field The data descriptor fields may be specified via either of two methods. - 1. The field may consist of four subfields each containing an evaluatable expression. - 2. The field may consist of a single SET or EQU symbol (category 9) which is associated with four values. ## Example: ADDN, A7, X0 AF, X1 0,7,0,16 1,7,0,16 .DESCRIPTOR .FIELDS ARE F,T,L,O. DSCRPTR SET 0,7,0,16 .BDP DESCRIPTOR ADDN.A7,X0 AF,X1 DSCRPTR DSCRPTR .ALTERNATE METHOD #### 7.4.2.1 BDP Descriptor. D Field The D field is a 3 bit reserved field in bit positions 01, 02 and 03 of the data descriptor. Interpretation of other Data Descriptor fields follow. This field is not specified in the instruction. ## 7.4.2.2 BDP\_Operand\_Type. I Field The T field shall consist of 4 bits, in bit positions 04 through 07 of the Data Descriptor, and shall describe the type of data representation used in the associated source or destination 7.0 CYBER 180 CPU SYMBOLIC MACHINE INSTRUCTIONS 7.4.2.2 BDP Operand Type, T Field field. The 16 values of the T field are assigned data type representations as follows: - O Packed Decimal No Sign - 1 Packed Decimal No Sign Leading Slack Digit - 2 Packed Decimal Signed - 3 Packed Decimal Signed Leading Slack Digit - 4 Unpacked Decimal Unsigned - 5 Unpacked Decimal Trailing Sign Combined Hollerith - 6 Unpacked Decimal Trailing Sign Separate - 7 Unpacked Decimal Leading Sign Combined Hollerith - 8 Unpacked Decimal Leading Sign Separate - 9 Alphanumeric - 10 Binary Unsigned - 11 Binary Signed - 12 Translated Packed Decimal Signed - 13 Translated Packed Decimal Signed Leading Slack Digit - 14 Translated Binary Unsigned - 15 Translated Binary Signed As determined by the operation code, source and destination field, data types shall be restricted to only those combinations which are defined as valid within the instruction descriptions. The designation of invalid I field combinations within the associated Data Descriptors shall result in the detection of an Instruction Specification error, the instruction's execution shall be inhibited and the corresponding program interruption shall occur. The term "freely compatible" as used in the BDP instruction descriptions, means that any allowable source field data type may be used with any allowable destination field data type. 7.0 CYBER 180 CPU SYMBOLIC MACHINE INSTRUCTIONS 7.4.2.3 BDP Operand Address, D Field ## 7.4.2.3 BDP Operand Address. D Field The PVA corresponding to the leftmost byte of a BDP source or destination field shall be obtained by utilizing the 16 bit 0 field of the corresponding data descriptor (bit positions 16 through 31) as a byte item count to be added as a sign extended 32 bit offset (2's complement for negative offset) to the byte number (BN) portion of the base PVA contained in Register Aj or Ak respectively. ## 7.4.2.4 BDP Operand Length. E and L Fields The length in bytes of a BDP source or destination field shall be obtained according to the value of the 1-bit F field (bit 00) of the corresponding descriptor as follows: ## E Length - Obtained from the 8 bit L field (bits 08 through 15) of the corresponding descriptor. - Obtained from bits 55-63 of XO Right for the first descriptor following an instruction, and from bits 55-63 of XI Right for the second descriptor following an instruction. Although field lengths as long as 256 bytes are possible, the length of a BDP operand shall be restricted to a smaller value for decimal and binary operations, according to the operand data type. These inclusive limits are the following: - 19 bytes for Packed Decimal (types 0 through 3, 12 and 13) - 38 bytes for Unpacked Decimal (types 4 through 8) - 8 bytes for Binary (types 10, 11, 14, and 15) When any BDP field length exceeds the specified maximum associated with a given data type, an Instruction Specification error shall be detected, the execution of that instruction shall be inhibited, and the corresponding program interruption shall occur. If F equals 1, then only the rightmost 9 bits of XO and X1 will be checked to determine whether or not the field length exceeds the maximum allowed. The other bits of XO and X1 will not be inspected. ## CYBER 180 II Assembler ERS CIDER 100 II ASSEMBLE END 7.0 CYBER 180 CPU SYMBOLIC MACHINE INSTRUCTIONS 7.4.3 DATA AND SIGN CONVENTIONS ### 7.4.3 DATA AND SIGN CONVENTIONS With respect to numeric data and sign conventions, interpretation shall be performed according to Type (T) where applicable, for characters (C), Digits (D) and Signs (S), using hexadecimal notation. NOTE: Data field examples are illustrated in the CYBER 180 Processor-Memory Model-Independent GDS. # 7.4.4 BDP NUMERIC The instructions in this subgroup shall provide the means for performing arithmetic, shift, conversion and comparison operations for byte fields in central memory consisting of numeric decimal data. Unless the length and format fields within the Data Descriptors associated with the source and destination fields, conform to the restrictions defined within the following instruction descriptions, the detection of a Length or Type error shall result in an Instruction Specification Error condition, the execution of the associated instruction shall be inhibited and the corresponding program interruption shall occur. Overflow into or other alteration of the slack digit of destination field types 1 and 3 is not allowed. The result shall be right justified in the destination field. If the decimal result is shorter than the destination field, the destination field shall be zero filled to the left. If the result is longer than the destination field, the result shall be truncated on the left as necessary. Thus, conceptually, these instructions shall process the data fields from right to left. Note that these conventions shall cover the end cases for numeric operands of length equal to 1 for all numeric data types. For instance, a Move Numeric from a type 5 operand to a type 3 or type 6 operand of length 1 would amount to an extraction of the source field sign. A source BDP operand of numeric type (0 through 8 and 12 through 15) and a length zero, shall be interpreted as the value zero. A destination BDP operand of length zero shall transform the associated instruction into a no-op. However, exception sensing for the source field shall occur normally, including the testing CIDEN TOO II WOOGHDICL END 7.0 CYBER 180 CPU SYMBOLIC MACHINE INSTRUCTIONS 7.4.4 BDP NUMERIC for an Arithmetic Loss of Significance or Arithmetic Overflow condition, provided the source field does not also have a length of zero. Minus zero shall be considered equivalent to plus zero by all the instructions in this subgroup, with respect to decimal numeric data. The representation for zero, zones and signs shall be normally determined by interpreting the T field from the Data Descriptor associated with the destination field. Division by zero shall not be allowed to the extent that the destination field in central memory shall not be changed and a Divide Fault condition shall be detected. Each source digit shall be checked for decimal digit validity. An invalid decimal digit shall cause an Invalid BDP Data condition to be detected and, if enabled, a program interruption shall occur upon the completion of these instructions. ## 7.4.4.1 Arithmetic a) Decimal Sum, D(Ak) replaced by D(Ak) plus D(Aj). 074 jk (2 descriptors) b) Decimal Difference, D(Ak) replaced by D(Ak) minus D(Aj). 075 jk (2 descriptors) c) Decimal Product, D(Ak) replaced by D(Ak) times D(Aj). 076 ik (2 descriptors) d) Decimal Quotient, D(Ak) replaced by D(Ak) divided by D(Aj). 077 jk (2 descriptors) Operation: These instructions shall arithmetically modify the initial contents of the destination field in central memory, (treated as an augend, minuend, multiplicand or dividend as determined by the operation code) by the contents of the source field in central memory (treated as an addend, subtrahend, multiplier or divisor as determined by the operation code) and shall transfer the decimal result consisting of a sum, difference, product or quotient, as determined by the operation code, to the destination field in central memory. CYBER 180 II Assembler ERS 7.0 CYBER 180 CPU SYMBOLIC MACHINE INSTRUCTIONS 7.4.4.1 Arithmetic /:T#7#1 A: | CHMCC|C Types: All Packed decimal types and all Unpacked decimal types, except for the Leading Sign formats, shall be freely allowed for decimal arithmetic; i.e., types 0 through 6, 12 and 13 shall be compatible for these instructions. Unpacked Decimal Leading Sign (both conventions) shall not be supported in the decimal arithmetic. A Numeric Move instruction must be generated to format the operands of those types prior to their use in arithmetic operations. Lengths: The maximum allowable lengths for the source and destination fields shall be determined according to their respective decimal data types. NOTE: Decimal operands shall be treated as integer values. When the results of these instructions exceed the capacity of the designated field such that significant digits are not stored into central memory, an Arithmetic Overflow condition shall be detected. When the corresponding user condition mask bit is set and the trap is enabled, instruction execution shall be inhibited and program interruption shall occur. #### 7.4.4.2 ADDN.SUBN.MULN.DIVN-Arithmetic a) Decimal Sum, D(Ak) replaced by D(Ak) plus D(Aj). ADDN - (Format = jk2 Op Code = 70 Ref# = 075) | + | + | | |---|-----------|-------------| | | operation | argument | | • | • | Ak,X1 SD DD | When the f field in the data descriptor is equal to 0, the length register (XO for source, X1 for destination) is not a required parameter. 7.0 CYBER 180 CPU SYMBOLIC MACHINE INSTRUCTIONS 7.4.4.2 ADDN, SUBN, MULN, DIVN-Arithmetic b) Decimal Difference, D(Ak) replaced by D(Ak) minus D(Aj). SUBN - (Format = jk2 Op Code = 71 Ref# = 075) | + | + | + | <br> | |---|-------------|---|------| | - | loperation | | <br> | | • | ISUBN,Aj,XO | • | | When the F field in the data descriptor is equal to 0, the length register (XO for source, X1 for destination) is not a required parameter. c) Decimal product, D(Ak) replaced by D(Ak) times D(Aj). MULN - (Format = jk2 Op Code = 72 Ref# = 076) | + | + | <del> </del> | - | |---|------------|--------------|---| | | loperation | argument | | | 1 | • | Ak,X1 SD DD | • | When the F field in the data descriptor is equal to 0, the length register (XO for source, X1 for destination) is not a required parameter. d) Decimal Quotient, D(Ak) replaced by D(Ak) times D(Aj). DIVN - (Format = jk2 Op Code = 73 Ref# = 077) | + | + | + | | |---|-------------|---|------| | | loperation | | <br> | | • | IDIVN,AJ,XO | • | | When the F field in the data descriptor is equal to 0, the length register (XO for source, X1 for destination) is not a required parameter. ## 7.4.4.3 SCLN.SCLR-Shift The following instructions shall move data initially contained in the source field to the destination field, and shall provide shifting of the data under control of a shift count. The shift count shall be derived in the following manner: The rightmost 8 bits from the instruction's D field shall be added to the rightmost 8 bits initially contained in bit positions 56 through 63 of Register Xi Right and the 8-bit sum shall represent the Rev: F 7.0 CYBER 180 CPU SYMBOLIC MACHINE INSTRUCTIONS 7.4.4.3 SCLN, SCLR-Shift computed shift count. Any overflow from the 8-bit sum is ignored. In this context, the contents of Register XO shall be interpreted entirely of zeroes. A zero shift count shall cause the instruction to act as a move only instruction. The 8-bit shift count shall be interpreted as a signed, binary integer. When this 8-bit shift count is positive, the direction of the shift shall be left with the number of decimal digit positions to be shifted determined by the value of the right-most seven bits (bit positions 57-63) of the shift count. When this 8-bit shift count is negative, the direction of the shift shall be right with the number of decimal digit positions to be shifted determined by the value of the 2's complement of the rightmost 7-bits (bit positions 57-63) of the shift count, with minus 128 (1000 0000) being interpreted as zero. Thus, positive shift counts shall provide the means for multiplying the source data field by powers of ten, and negative shift counts shall provide the means for dividing the source data fields by powers of ten, as the source data is moved to the destination field. When non-zero digits are shifted left end-off, or truncated on the left, an Arithmetic Loss of Significance condition shall be detected. If the corresponding user condition mask bit is set and the trap is enabled, instruction execution shall be inhibited and program interruption shall occur. Shifting shall be accomplished end-off with zero fill on the appropriate end(s) as required to accommodate the length and type of the receiving field. (For example, when the destination field is longer than the source field, and the difference in field lengths is greater than the left shift count, such a scale instruction shall provide zero fill, to the extent required, on both the right and left ends of the destination field result). Types: Source field data shall be restricted to Types 0 through 6, 9, 12 and 13, all of which shall be freely compatible with allowable destination field data Types of 0 through 6, 12 and 13. Lengths: The maximum allowable lengths for the source and destination fields shall be determined according to their respective decimal data types. CYBER 180 II Assembler ERS 7.0 CYBER 180 CPU SYMBOLIC MACHINE INSTRUCTIONS 7.4.4.3 SCLN, SCLR-Shift 7.4.4.3 SCLN, SCLR-Shift a) Decimal Scale, D(Ak) replaced by D(Aj), scaled per (Xi) Right plus D. SCLN - (Format = jkiD2 Op Code = E4 Ref# = 078) | + | <b>.</b> | + | |---|------------|-------------------| | | loperation | largument | | • | • | [Ak,X1,Xi,D SD DD | When the F field in the data descriptor is equal to 0, the length register (XO for source, X1 for destination) is not a required parameter. b) Decimal Scale Rounded, D(Ak) replaced by rounded D(Aj), scaled per (Xi) Right plus D. SCLR - (Format = jkiD2 Op Code = E5 Ref# = 079) | + | + | + | |---|------------|-------------------| | - | loperation | largument | | • | • | IAK,X1,XI,D SD DD | When the F field in the data descriptor is equal to 0, the length register (XO for source, X1 for destination) is not a required parameter. These instructions shall move and scale the decimal data field initially contained in the source field to the destination field. They shall transfer the sign of the source field to the destination field without change (unless the results consist entirely of zeroes and there is no loss of significance, in which case the sign of the destination field shall be made positive, or unless the result would otherwise contain a non-preferred sign, in which case the sign of the destination field shall contain the preferred sign). When specified by means of the operation code, rounding shall be performed for negatively signed scale factors by adding five to the last digit shifted end-off and propagating carries, if any, through the decimal result transferred to the destination field. Thus the absolute value shall be rounded upwards. ### CYBER 180 II Assembler ERS 7.0 CYBER 180 CPU SYMBOLIC MACHINE INSTRUCTIONS 7.4.4.4 MDVN-Move #### 7.4.4.4 MOYN-Move a) Numeric Move, D(Ak) replaced by D(Ai), after formatting. MOVN - (Format = ik2 Op Code = .75 Ref # = .092) | + | + | + | | |---|------------|-----------|--| | | loperation | largument | | | 1 | • | Ak,XI SD | | When the F field in the data descriptor is equal to 0, the length register (XO for source, X1 for destination) is not a required parameter. This instruction formats the number obtained from the source field and transfers the result to the destination field. The source field validated according to the T field from its associated descriptor; the source field is reformatted according to the T field from the data descriptor associated with the destination field and the result is transferred to the destination field. #### 7.4.4.5 CMPN-Comparison a) Decimal Compare, D(Aj) to D(Ak), result to X1 Right. CMPN - (Format = jk2 Op Code = 74 Ref# = 083) | + | + | + | <br> | |---|-------------|------|------| | | loperation | -1/- | <br> | | ~ | ICMPN,AJ,XO | 7 | | When the F field of the source descriptor is equal to 0, X0 is not a required parameter. This instruction algebraically compares the decimal contents of the source field to the decimal contents of the destination field and transfers a 32-bit halfword to Register X1 Right according to the results of the comparison. When the results of the source and destination fields are equal, the entire 32-bit positions of Register X1 Right are cleared. CYBER 180 II Assembler ERS 7.0 CYBER 180 CPU SYMBOLIC MACHINE INSTRUCTIONS 7.4.4.5 CMPN-Comparison When the contents of the source field are greater than the contents of the destination field, Register X1 Right is cleared in bit positions 32 and 34 through 63, and set in bit position 33. When the contents of the source field are less than the contents of the destination field, Register X1 Right is cleared in bit positions 34 through 63 and set in bit positions 32 and 33. . .... . 7.4.5 BYTE The instructions in this subgroup provide the means for comparing, scanning, translating, moving and editing byte fields in central memory to the extent defined by the following descriptions. ## 7.4.5.1 CMPB.CMPC-Comparison a) Byte Compare, D(Aj) to D(Ak), result to X1 Right, Index to X0 Right. CMPB - (Format = jk2 Op Code = 77 Ref# = 084) | 4 | + | · | <br> | |--------|-------------|----------|------| | llabel | loperation | argument | | | • | ICMPB,AI,XO | • | | b) Byte Compare Collated, D(Aj) to D(Ak), both translated per (Ai) plus D, result to X1 Right, Index to X0 Right. CMPC - (Format = jkiD2 Op Code = E9 Ref# = 085) | llabel | loperation | | | |--------|------------|-------------|--| | * | • | lak,X1,Ai,D | | These instructions compare the bytes contained in the source field to the bytes contained in the destination field and transfer the results to the comparison to Register X1 Right. The comparison proceeds from left to right. When the field lengths are unequal, trailing space characters are used for the field having the shorter length. The maximum length for each 86/10/17 CYBER 180 II Assembler ERS Rev: F 7.0 CYBER 180 CPU SYMBOLIC MACHINE INSTRUCTIONS 7.4.5.1 CMPB, CMPC-Comparison operand is 256 bytes. The comparison continues until the longer field has been exhausted or until an "inequality" is detected between corresponding bytes from the source and destination fields according to the following definitions. For the compare instruction, inequality between the bytes obtained directly from the source and destination fields results in the completion of the comparison. For the Collated Compare instruction inequality of the bytes obtained directly from the source and destination fields results in the translation of both bytes by means of a translation table, and inequality of the post\_translation bytes results in the completion of the comparison. When the translated bytes are equal, and the longer field has not been exhausted, comparison between the corresponding bytes obtained directly from the source and destination fields is resumed. Each byte shall be translated by using its value as a positive offset to be added to the beginning (leftmost) address of the Translation Table, (Ai) + D, for the purpose of addressing the translated byte to be read from central memory. 7.4.5.2 SCNB=Byte\_Scan a) Byte Scan While Non-Member, D(Ak) for presence bit in (Ai)+D, index to XO Right, character to X1 Right. SCNB - (Format = jkiD1 Op Code = F3 Ref# = 086) | + | + | + | | |---|-------------|----------|----| | | loperation | argument | | | 1 | ISCNB,AJ,XO | • | DD | The Aj field of this instruction is unused and optional. Operation: The operation shall proceed from left to right on the destination field addressed by D(Ak). One character at a time shall be taken from this character string and used as a bit address into the string addressed by a PVA whose Ring Number (RN) and Segment (SEG) are obtained from Ai, and whose Byte Number (BN) is formed by the 32-bit sum (ignoring overflow) of the rightmost 32 bits of Ai plus the instruction's 12-bit D field extended to the left with 20 zeroes. The scan shall terminate if the bit thus addressed in ON or if the destination field has been exhausted; otherwise the next character in D(Ak) is considered. Source Field: The operand addressed by Ai+D shall be interpreted as a bit string consisting of 256 bits (32 bytes). The entire CYBER 180 II Assembler ERS 7.0 CYBER 180 CPU SYMBOLIC MACHINE INSTRUCTIONS 7.4.5.2 SCNB-Byte Scan table, consisting of 256 bits, may be loaded internally to the processor, on a model dependent basis, before any operation on the data is performed. Destination Field: The type field in D(Ak) shall be ignored. The operand addressed by D(Ak) shall be interpreted as a byte string, and restricted to no more than 256 characters. The binary value of the sequence number in the string of the byte which caused the scan to terminate shall be placed right justified into XO Right. The binary value of the character itself which caused the scan to terminate shall be placed right justified into X1 Right. If the scan stops by exhaustion of the characters in the byte string. XO Right shall contain the length of the original byte string and X1 Right shall be set in bit position 32 and cleared in bit positions 33 through 63. ### 7.4.5.3 IRANB=Iranslate a) Byte Translate, D(Ak) replaced by D(Aj), translated per (Ai) plus D. TRANB - (Format = jkiD2 Op Code = EB Ref# = 088) | + | + | + | | |---|-----------|---------------|--| | | operation | argument | | | * | • | Ak,X1,Ai,D SD | | When the F field in the data descriptor is equal to 0, the length register (XO for source, XI for destination) is not a required parameter. This instruction translates each byte contained in the source field according to the translation table in central memory and transfers the results of the byte-by-byte translation to the destination field. The translation table is addressed in a manner identical to that previously described for the Collated Compare instruction. The type fields in the Data Descriptors associated with the source field and the destination field are ignored. Both operands are restricted to no more than 256 bytes. The translation operation shall occur from left to right with CYBER 180 II Assembler ERS 7.0 CYBER 180 CPU SYMBOLIC MACHINE INSTRUCTIONS 7.4.5.3 TRANS-Translate each source byte used as a positive offset to be added to the beginning (leftmost byte) address of the translation table for the purpose of permitting each byte's translation. Translated bytes, thus obtained from the translation table, shall be transferred to the destination field. The translation operation shall terminate after the destination field length has been exhausted. When the source field length is greater than the destination field length, rightmost bytes from the source field shall be truncated, to the extent required, with respect to the translation operation. When the source field length is less than the destination field length, translated space characters shall be used to fill the rightmost byte positions of the destination ## 7.4.5.4 MOVB=Move field to the extent required. a) Move Bytes, D(Ak) replaced by D(Aj). MOVB - (Format = jk2 Op Code = 76 Ref# = 089) | + | + | <del> </del> | | |---|------------|--------------|--| | | loperation | argument | | | • | • | Ak,X1 SD DD | | When the F field in the data descriptor is equal to 0, the length register (XO for source, X1 for destination) is not a required parameter. This instruction provides the means for moving the bytes contained in the source field to the destination field. The type fields of the source and destination data descriptors are ignored. Field lengths are restricted to a maximum of 256 bytes. #### 7.4.5.5 EDII=Edit a) Edit, D(Ak) replaced by D(Aj) edited per M((Ai) + D). EDIT - (Format = jkiD2 Op Code = ED Ref# = 091) | + | | + | | |---|------------|-------------|--| | | loperation | " w" | | | 1 | • | lak,X1,Ai,D | | The Aj field is unused and optional. When the F field in the data descriptor is equal to 0, the length register (XO for CYBER 180 II Assembler ERS 7.0 CYBER 180 CPU SYMBOLIC MACHINE INSTRUCTIONS 7.4.5.5 EDIT-Edit source, X1 for destination) is not a required parameter. This instruction shall edit the digits or characters contained in the source field according to an edit mask in central memory and shall transfer the result to the destination field. The edit mask shall be addressed by a PVA whose Ring Number (RN) and Segment (SEG) are obtained from Ai, and whose Byte Number (BN) is formed by the 32-bit sum (ignoring overflow) of the rightmost 32 bit of Ai plus the instruction's 12-bit D field extended to the left with 20 zeroes. The edit mask shall consist of a one byte length indication followed by a string of micro-operations. The length indication shall include the byte containing the length. #### 7.4.6 IMMEDIATE DATA Within this instruction group, the Immediate Data Byte is an 8 bit field formed by the 2's complement addition of bits 56-63 (Xi) Right and the rightmost 8 bits of the instruction's D field. Overflow is ignored on this summation. In this context, the contents of Register XO shall be interpreted as consisting entirely of zeroes. ## 7.4.6.1 MOVI-Move Immed Data (Xi) Right plus D to D(Ak) MOVI - (Format = jkiDl Op Code = F9 Ref# = 154) | + | + | - | |---|-----------|-------------| | | operation | argument | | 1 | • | lAk•X1•i DD | When the F field in the data descriptor is equal to 0, the length register (X1 for destination) is not a required parameter. This instruction shall move the Immediate Data Byte to the destination field after format conversion per the destination field type and the j field sub-operation code. The least significant 2 bits of the j field shall be used as an encoding of the operation to be performed: - a) If = 00, the unsigned (considered positive) numeric value (Type 10) contained in the Immediate Data Byte shall be moved right justified to the receiving field, which must be of type 10, 11, 14 or 15. If necessary, the destination field is filled with zeroes on the left. - b) If = 01, the decimal numeric value (Type 4) contained in the CYBER 180 II Assembler ERS 7.0 CYBER 180 CPU SYMBOLIC MACHINE INSTRUCTIONS 7.4.6.1 MOVI-Move Immed Data (XI) Right plus D to D(Ak) Immediate Data Byte shall be moved right justified, to the receiving field after possible reformatting to match the data type of the destination. If the format requires a sign, a positive sign shall be supplied. The destination shall be restricted to one of the decimal data types 0 through 6, 12 or 13. This move shall be executed according to the rules of the numeric move for truncation, padding and validation. Each source digit shall be checked for decimal digit validity. An invalid decimal digit shall cause an Invalid BDP Data condition to be detected. When the corresponding user mask bit is set, and the trap is enabled, instruction execution shall be inhibited and program interruption shall occur. - c) If = 10, the ASCII character contained in the Immediate Data Byte is repeated left to right in the receiving field. The destination data type shall be ignored. - d) If = 11, the ASCII character contained in the Immediate Data Byte is moved left justified into the receiving field, the rest of that field is space filled. The destination data type shall be ignored. 7.4.6.2 CMPI-Compare Immed\_Data(Xi) Right\_plus\_D\_to\_D(Ak) CMPI - (Format = ikiD1 Op Code = FA Ref# = 155) This operation shall, depending on the value of the j field, compare the explicit value contained in the Immediate Data Byte to D(Ak) after a possible reformatting to match the data type and shall transfer a 32-bit half word to Register X1 Right according to the result of the comparison. When the contents of the source and destination fields are equal, the entire 32-bit positions of Register X1 Right shall be cleared. The rightmost two bits of the j field shall be used as an encoding of the operation to be performed: a) If J=00, the unsigned (considered positive) numeric value (Type 10) contained in the Immediate Data Byte shall be processes to it wild control to an anti- 7.0 CYBER 180 CPU SYMBOLIC MACHINE INSTRUCTIONS 7.4.6.2 CMPI-Compare Immed Data(Xi) Right plus D to D(Ak) compared to the contents of field D(Ak), which must be of type 10, 11, 14 or 15. If field D(Ak) is longer than one byte, then the Immediate Data Byte will be zero filled to the left as necessary. b) If j=01, the decimal numeric value (Type 4) contained in the Immediate Data Byte shall be compared to the contents of field D(Ak) after possible reformatting to match the data type of field D(Ak). If the format requires a sign, a positive sign shall be supplied. The D(Ak) field shall be restricted to one of the decimal data types 0 through 6, 12 or 13. If field D(Ak) is longer than one byte, then the Immediate Data Byte shall be zero filled to the left as necessary. Each source digit shall be checked for decimal digit validity. An invalid decimal digit shall cause an Invalid BDP Data condition to be detected. When the corresponding user mask bit is set, and the trap is enabled, instruction execution shall be inhibited and program interruption shall occur. - c) If j=10, the ASCII character contained in the Immediate Data Byte shall be compared left to right with each successive byte contained in the D(Ak) field. The data type of field D(Ak) shall be ignored. - d) If j=11, the ASCII character contained in the Immediate Data Byte shall be compared to the leftmost byte in field D(Ak). If the comparison is equal and if field D(Ak) is longer than one byte, then a space character shall be compared left to right with each successive remaining byte contained in the D(Ak) field. The data type of field D(Ak) shall be ignored. When the contents of the source field are greater than the contents of the destination field, Register X1 Right shall be cleared in bit positions 32 and 34 through 63 and shall be set in bit position 33. When the contents of the source field are less than the contents of the destination field, Register X1 Right shall be cleared in bit positions 34 through 63 and shall be set in bit positions 32 and 33. The interpretation of the source and destination fields are analogous to those described under the Move Immediate Data Instruction. 86/10/17 ### CYBER 180 II Assembler ERS Rev: F 7.0 CYBER 180 CPU SYMBOLIC MACHINE INSTRUCTIONS 7.4.6.3 ADDI-Add Immed Data (XI) Right plus D to D(Ak) 7.4.6.3 ADDI-Add Immed Data (Xi) Right plus D to D(Ak) ADDI - (Format = jkiDl Op Code = FB Ref# = 156) | + | <br>+ | | |---|-----------|-------------| | | operation | argument | | 1 | • | lAk,X1,j DD | When the F field in the data descriptor is equal to 0, the length register (XO for source, X1 for destination) is not a required parameter. This operation shall add the explicit integer value contained in the Immediate Data Byte to D(Ak) after a possible conversion to match the destination data type. Source: The Immediate Data Byte is used to store the integer value of the addend. The j field is used as an encoding of the type of the data contained in the Immediate Data Byte. The least significant bit of the j field is decoded as follows: - a) If = 0, the Immediate Data Byte, contains an unsigned (considered positive) binary integer value; Immediate Data Byte = Data Type 10. - b) If = 1, the Immediate Data Byte, contains one ASCII character representing a decimal digit; if invalid decimal data is encountered in the Immediate Data Byte, an Invalid BDP Data condition shall be detected. When the corresponding user condition mask bit is set and the trap is enabled, instruction execution shall be inhibited and program interruption shall occur. Immediate Data Byte = Data Type 4. If the source corresponds to case a) above, the destination shall be confined to types 10, 11, 14 and 15. If the source corresponds to case b) above, the destination shall be confined to types 0 through 6, 12 and 13. 7.5 ELOAIING POINT INSTRUCTIONS ### CYBER 180 II Assembler ERS 7.0 CYBER 180 CPU SYMBOLIC MACHINE INSTRUCTIONS 7.5.1 GENERAL DESCRIPTION #### 7.5.1 GENERAL DESCRIPTION A floating point number consists of a signed exponent and a signed fraction. The signed exponent can also be referred to as the characteristic and the signed fraction can also be referred to as the coefficient. The quantity expressed by a floating point number is of the form (f)2x where f represents the signed fraction and x represents the signed exponent of the base 2. The exponent base of 2 is an implied constant for all floating point numbers and thus does not explicitly appear in any floating point format. ## 7.5.2 FORMATS Floating point data occupies one of two fixed length formats; 64-bit word (Single Precision) or 128-bit doubleword (Double Precision). In both the single and double precision formats, the leftmost bit position, 00, is occupied by the sign of the fraction. The fifteen bit positions immediately to the right of bit 00, 01 through 15, occupied by the signed exponent. The field immediately to the right of the signed exponent is occupied by the fraction which in single precision format consists of 48 bits and in double precision format consists of 96 bits, according to the following figures. | • | 15 16 | 631 | |---------------------|---------------------|-----| | 15 Signed Exponer | nt 48-bit fractio | n Î | Single Precision Floating Point Number 7.0 CYBER 180 CPU SYMBOLIC MACHINE INSTRUCTIONS | 1.0.2 FURMAIS | | |---------------|--| | | | | | | | 100101 | 15 16 | 5 and 40 AM | 631 | |--------------|----------------------|-------------------------------------------------|-----| | IS ISigned E | xponent Leftmost 4 | 8-bits of the fractio | n İ | | 164165 | 71172 | | 127 | | | xponent Rightmost | 48-bits of fraction | | Double Precision Floating Point Number A double precision floating point number consists of two single precision floating point numbers located in consecutively numbered X Registers. The two single precision floating point numbers comprising a double precision floating point number are referred to as the leftmost and rightmost parts as contained in the Xn and Xn+1, respectively. The leftmost part may be any single precision floating point number and when it is normalized, (the leftmost bit of the fraction, in bit position 16, is equal to a one) the double precision floating point number is considered to be normalized. The sign of the fraction and the characteristic of the leftmost part constitutes the sign of the fraction and the characteristic of the double precision number. The fraction field of the leftmost part constitutes the leftmost 48 bits of the 96-bit double precision fraction. fraction field of the rightmost part constitutes the rightmost 48 bits of the 96-bit double precision fraction. The sign of the fraction and the characteristic of the rightmost part cannot be utilized from any number constituting an input operand (argument) to a double precision floating point operation. Such operations assume that the sign of the fraction of the rightmost part is the same as the sign of the fraction of the leftmost part and that the characteristic of the rightmost part is 48 less than the characteristic of the leftmost part. However, the formation of a double precision floating point result includes making the sign of the fraction of the rightmost part the same as that of the leftmost part and, except for certain cases non-standard forms of floating point results, also includes making the characteristic of the rightmost part 48 less than the characteristic of the leftmost part. The following table illustrates hexadecimal exponent codes for corresponding non-standard as well as standard floating point numbers: 7.0 CYBER 180 CPU SYMBOLIC MACHINE INSTRUCTIONS 7.5.2 FORMATS | | Hexadecimal Exponent including coefficient sign | | | | |--------------------------------------------------------------|-------------------------------------------------|------------------------------------------|--------------|-------------------------------------------------------------------------------| | | | Actual Expo | nent (to the | e base of 2) | | | | | Input Argu | ments | | | | | | Results | | | 7XXX | | Indefinite | 7000.0>0 | | Coefficient | 1 ^ | 2**12287<br> | Infinite | Dverflow Mask = 0 : | | Sign Equal to 0 (Positive numbers) | ^<br> 1<br> 4000<br> 3FFF<br> 1 | 2**4095<br> | Standard | As Shown | | | <br> v | 2**(-4097)<br> <br> v<br> 2**(-12288) | Zero | Underflow Mask = 0 :<br> 000.00>00<br> Underflow Mask = 1 :<br> As Shown | | | OXXX<br>18XXX | | Zero | Not Applicable | | | ^ | | <br> Zero | Underflow Mask = 0 :<br> 10000.00>00<br> Underflow Mask = 1 :<br> As Shown | | Sign Equal<br> to 1<br> (Negative<br> Numbers)<br> <br> | BFFF<br>COOO | | Standard | As Shown | | | D000 | 2**4096 | | Overflow Mask = 0 : | ### CYBER 180 II Assembler ERS 7 A CYDED 19A CON CYMROL TO MACHINE INSTRUCTIONS | 7.0 | CYBE | R 180 | CPU | SYMBOLIC | MACHINE | INSTRUCTIONS | | |------|------|-------|-----|----------|---------|--------------|--| | 7.5. | 2 FO | RMATS | | | | | | | - | 1 | | | D000.00>00<br> Overflow Mask = 1 :<br> As Shown | |---|--------|-----|---|-------------------------------------------------| | 1 | \<br>V | · · | • | 7000.00>00 | ## Floating Point Representation ### 7.5.3 EXPONENT ARITHMETIC When the exponent fields from input arguments are added, as for floating point multiplication, or subtracted, as for floating point division, the exponent arithmetic is performed algebraically in 2's complement mode. Moreover, such operations take place, conceptually, as if the bias were removed from each exponent field prior to performing the addition or subtraction and then restored following exponent arithmetic so as to correctly bias the exponent result. Exponent Underflow and Overflow conditions are detected for all single precision, but only for the leftmost part of double precision floating point results. When the generation of the exponent of the rightmost part, by reducing the exponent of the leftmost part by 48, results in underflow for the rightmost part, this underflow is not to be detected and utilization of an Out of Range exponent permits the rightmost part of the double precision floating point number to correctly express its value. ## 7.5.4 NORMALIZATION A normalized floating point number has a one in the leftmost bit position, 16, of the fraction field. If the leftmost bit of the fraction is a zero, the number is considered unnormalized. Normalization takes place when intermediate results are changed to final results. Numbers with zero fractions cannot be normalized and such fractions remain equal to zero. For intermediate results in which coefficient overflow has not occurred and the initial operands were normalized, the normalization process consists of left shifting the fraction until the leftmost bit position contains a one and correspondingly reducing the characteristics by the number of positions shifted. For intermediate results in which coefficient overflow has occurred, the normalization process consists of right shifting the fraction one bit position and correspondingly 7.0 CYBER 180 CPU SYMBOLIC MACHINE INSTRUCTIONS 7.5.4 NORMALIZATION increasing the characteristic by one. For double precision floating point numbers, the entire fraction participates in the normalization such that the rightmost part may or may not appear as a normalized single precision number as determined by the value of the fraction. For quotient and product instructions (reference numbers 103, 104, 107, 108) if the operands are unnormalized, the results may be unnormalized. When exponent arithmetic operations on standard floating numbers generate an intermediate exponent which is Out of Range, but normalization requirements generate an adjusted exponent which is no longer Out of Range, then neither Exponent Overflow nor Exponent Underflow is recorded for the final results. ## 7.5.5 DOUBLE PRECISION REGISTER DESIGNATORS The terms "Xk+1" and "Xj+1" is used to designate an X Register associated with the rightmost part of a double precision floating point number. When the leftmost part of a double precision floating point number, as designated by the terms "Xk" and "Xj" is associated with Register XF (in hexadecimal notation) the terms "Xk+1" and "Xj+1" are interpreted as designating Register XO. #### 7.5.6 CONVERSION The instructions within this subgroup provide the means for converting 64-bit words, contained in the X Registers, between floating point and integer formats. ## 7.5.6.1 CNIE-Convert From Integer to Eloating Point a) Floating Point Convert from Integer, Floating Point (Xk) formed from Integer (Xj). CNIF - (Format = jk Op Code = 3A Ref# = 097) | + | + | | |----------|------------|--------------| | <u> </u> | 1 | • | | llabel | loperation | laroument | | - | . * | | | * | + | <del>+</del> | | I | 1 CAITE | tvi v: | | I | ICNIF | [ | 86/10/17 ## CYBER 180 II Assembler ERS Rev: F 7.0 CYBER 180 CPU SYMBOLIC MACHINE INSTRUCTIONS 7.5.6.2 CNFI-Convert Floating Point to Integer 7.5.6.2 CNEI-Convert Floating Point to Integer a) Floating Point Convert to Integer, Integer (Xk) formed from Floating Point (Xj). ``` CNFI - (Format = jk Op Code = 38 Ref# = 098) ``` | + | + | + | |---|------------|----------| | | loperation | argument | | 7 | CNFI | | 7.5.7 ARITHMETIC The instructions within this subgroup provide the means for performing arithmetic operations on floating point numbers to the extent described in the following subparagraphs. 7.5.7.1 ADDE.SUBE-Add/Subtract.\_Xk a) Floating Point Sum, (Xk) replaced by (Xk) plus (Xj). ADDF - (Format = jk Op Code = 30 Ref# = 099) | llabel | operation | argument | |--------|-----------|----------| | • | ADDF | • | b) Floating Point Difference, (Xk) replaced by (Xk) minus (Xj). SUBF - (Format = jk Op Code = 31 Ref# = 100) ### CYBER 180 II Assembler ERS 7.0 CYBER 180 CPU SYMBOLIC MACHINE INSTRUCTIONS 7.5.7.2 MULF-Product to XK ## 7.5.7.2 MULE-Product\_to\_XK a) Floating Point Product, (Xk) replaced by (Xk) times (Xj). MULF - (Format = jk Op Code = 32 Ref# = 103) | + | + | <del></del> | |---|------------|-------------| | | loperation | argument | | • | * | lxk,xj | # 7.5.7.3 DIVE-Quotient\_to\_XK a) Floating Point Quotient, (Xk) replaced by (Xk) divided by (Xj). DIVF - (Format = jk Op Code = 33 Ref# = 104) | + | + | | |---|-----------|-----------| | | operation | largument | | • | IDIVE | | ## 7.5.7.4 ADDD.SUBD-Add/Subtract. Xk and Xk+1 a) Floating Point DP Sum (Xk, Xk+1) replaced by (Xk, Xk+1) plus (Xj, Xj+1). ADDD - (Format = jk Dp Code = 34 Ref# = 105) | + | + | | |---|-----------|-----------| | | operation | largument | | • | I ADDD | • | 86/10/17 ### CYBER 180 II Assembler ERS Rev: F. 7.0 CYBER 180 CPU SYMBOLIC MACHINE INSTRUCTIONS 7.5.7.4 ADDD, SUBD-Add/Subtract, Xk and Xk+1 Floating Point DP Difference (Xk, Xk+1) replaced by (Xk, Xk+1) minus (Xi, Xi+1). SUBD - (Format = jk Op Code = 35 Ref# = 106) | + | + | | |---|-----------|----------| | - | operation | argument | | • | I SUBD | * | ### 7.5.7.5 MULD-Product to Xk and Xk+1 Floating Point DP Product (Xk, Xk+1) replaced by (Xk, Xk+1) times $(X_i, X_i+1)$ . MULD - (Format = jk Op Code = 36 Ref# = 107) | llabel | loperation | argument | |--------|------------|----------| | • | MULD | • | ## 7.5.7.6 DIVD-Quotient\_to\_Xk\_and\_Xk+1 Floating Point DP Quotient, (Xk, Xk+1) replaced by (Xk, Xk+1) divided by (Xj, Xj+1). DIVD - (Format = jk Op Code = 37 Ref# = 108) ``` llabel loperation largument DIVD IXk,Xi ``` 7.5.8 BRANCH The instructions in this subgroup consist of conditional branch instructions. Each of these conditional branch instructions perform a comparison between two floating point numbers. Then, based on the relationship between the results of that comparison and the branch condition as specified by means of the instruction!s CYBER 180 II Assembler ERS 7.0 CYBER 180 CPU SYMBOLIC MACHINE INSTRUCTIONS 7.5.8 BRANCH assertion and analysis and tional branch instruction perform operation code, each conditional branch instruction performs either a normal exit or a branch exit. Normal Exit: When the results of a comparison do not satisfy the branch condition as specified by the operation code, a normal exit is performed. A normal exit for all conditional branch instructions consist of adding four to the rightmost 32 bits of the PVA obtained from the P Register with that 32-bit sum returned to the P Register in its rightmost 32-bit positions. Branch Exit: When the results of a comparison satisfy the branch condition as specified by the operation code, a branch exit is performed. A branch exit consists of expanding the 16-bit Q field from the instruction to 31 bits by means of sign extension, shifting these 31 bits left one bit position with a zero inserted on the right and adding this 32-bit shifted result to the rightmost 32-bits of the PVA obtained from the P Register with the 32-bit sum returned to the P Register in its rightmost 32-bit positions. The Assembler sets the instruction's Q field according to the value of the 'label' subfield of the instruction mnemonics, which must correspond to a label of an Assembler statement within the currently active section. Relative addresses cannot span section boundaries. ## 7.5.8.1 BREEQ.BRENE.BREGI.BREGE-Compare and Branch a) Branch to (P) displaced by 2\*Q if Floating Point (Xj) equal to (Xk). BRFEQ - (Format = jkQ Op Code = 98 Ref# = 109) | + | | | |---|-----------|-------------| | | operation | argument | | • | • | Xj,Xk,label | label - byte address of the new location. 86/10/17 ### CYBER 180 II Assembler ERS equal to (Xk). Rev: F 7.0 CYBER 180 CPU SYMBOLIC MACHINE INSTRUCTIONS 7.5.8.1 BRFEQ,BRFNE,BRFGT,BRFGE-Compare and Branch b) Branch to (P) displaced by 2\*Q if Floating Point (X) not BRFNE - (Format = jkQ Op Code = 99 Ref# = 110) | + | + | | |---|------------|-------------| | | loperation | argument | | • | * | Xj,Xk,label | label - byte address of the new location. c) Branch to(P) displaced by 2\*Q if Floating Point (Xj) greater than (Xk). BRFGT - (Format = jkQ Op Code = 9A Ref# = 111) label - byte address of the new location. d) Branch to (P) displaced by 2\*Q if Floating Point (Xj) greater than or equal to (Xk). BRFGE - (Format = jkQ Op Code = 98 Ref# = 112) label - byte address of the new location. 7.0 CYBER 180 CPU SYMBOLIC MACHINE INSTRUCTIONS 7.5.8.2 BROVR, BRUND, BRINF-Exception Branch ## 7.5.8.2 BROVR.BRUND.BRINE-Exception Branch a) Branch to (P) displaced by 2\*Q if Floating Point Exception per j contained in Xk. The values of the rightmost 2 bits of the j field from the instruction are associated with exception conditions as follows: if 00, Exponent Overflow if 01, Exponent Underflow if 10 or 11, Indefinite BROVR - (Format = jkQ Op Code = 9E Ref# = 113) BRUND - (Format = jkQ Op Code = 9E Ref# = 113) BRINF - (Format = jkQ Op Code = 9E Ref# = 113) | llabel | loperation | argument | |--------|-----------------|-----------| | i | BROVR | İ | | 1 | BRUND<br> BRINF | Xk, label | label - byte address of the new location. The Assembler computes the value of j from the specific instruction mnemonic used. ## 7.5.8.3 CMPE-Compare a) Compare Floating Point (Xi) to (Xk), result to X1 Right. CMPF - (Format = jk Op Code = 3C Ref# = 114) | + | + | + | |---|------------|-----------| | | loperation | largument | | | • | IX1,Xj,Xk | . .... . ### CYBER 180 II Assembler ERS 7.0 CYBER 180 CPU SYMBOLIC MACHINE INSTRUCTIONS 7.6 SYSTEM INSTRUCTIONS ## 7.6 SYSIEM\_INSTRUCTIONS ## 7.6.1 NON-PRIVILEGED MODE This class of instructions is permitted to execute in any processor mode. #### 7.6.1.1 EXECUTE. HALT. SYNC a) Execute Algorithm - Processor Model Dependent Instruction. EXECUTE - (Format = SikiD Op Code = CO-C7 Ref# = 139) b) Program Error. HALT - (Format = jk Op Code = 00 Ref# = 121) | + | <del> </del> | | |---|--------------|----------| | | operation | argument | | * | HALT | | c) Synchronization - Scope Loop Sync. SYNC - (Format = ik Op Code = 01 Ref# = 194) | llabel | loperation | - | |--------|------------|-----------| | • | SYNC | +<br>1 jk | #### 7.6.1.2 CALLSEG.CALLREL-Call These instructions save the "environment", as designated by the contents of Register XO Right, in the stack frame save area pointed to by the Dynamic Space Pointer initially contained in Register AO. The stack associated with the current ring of execution, as determined by the RN field initially contained in the P Register, "pushed" by transferring the Dynamic Space Pointer, modified in its rightmost 32-bit positions by the 7.0 CYBER 180 CPU SYMBOLIC MACHINE INSTRUCTIONS 7.6.1.2 CALLSEG, CALLREL-Call addition of 8 times the number of words stored into the stack frame save area, to the appropriate Top of Stack entry in the executing process's Exchange Package. The AO, A1, and A2 Registers altered to reflect changes with respect to the Current and Previous Stack Frames and the A3, and A4 Registers shall be altered to reflect pertinent parameter changes as required, in accomplishing this transfer of control from a "calling" procedure to a "called" procedure. Register assignments are as follows: - (AO) Dynamic Space Pointer - (A1)- Current Stack Frame Pointer - (A2)- Previous Save Area Pointer - (A3)- Binding Section Pointer - (A4)- Argument Pointer - (XO) RIGHT the Save Environment is defined as follows: Bits 52-55: Xs = Starting X-Reg to save Bits 56-59: At = Final A-Reg to save Bits 60-64: Xt = Final X-Reg to save a) Call per (Aj) displaced by 8\*Q, Arguments per (Ak). The PVA obtained from Register Aj is modified in its rightmost 32-bit positions by the addition of the zero-extended Q field from the instruction, (shifted left 3-bit positions with zeroes inserted on the right), and the resulting PVA is used to address a Code Base Pointer from a Binding Section Segment. This Code Base Pointer is translated into a PVA used to address the first instruction to be executed in the "called" procedure. The ring of execution of the called procedure, P(RN) final, shall be used to obtain a Top of Stack pointer from the process' Exchange Package to be used as the new Current Stack Frame Pointer. CALLSEG - (Format = jkQ Dp Code = B5 Ref# = 115) label - byte address of entry point in the new procedure, must be on a word boundary. Rev: F 7.0 CYBER 180 CPU SYMBOLIC MACHINE INSTRUCTIONS 7.6.1.2 CALLSEG, CALLREL-Call **b**) Call to (P) displaced by 8\*Q, Binding Section Pointer per (Ai), Arguments per (Ak). The P Register shall be modified in its rightmost 32-bit positions by the sign extended Q field from the instruction. (left shifted 3-bit positions with zeroes inserted on the right) and the final contents of the P Register shall be made zeroes in the least significant three bit positions (61-63) and shall be used to address the first instruction to be executed in the "called" procedure. CALLREL - (Format = jkQ Op Code = 80 Ref# = 116) | label | | loperation | argument label - byte address of the location to continue execution, must be on a boundary. The Assembler computes the value of Q from the "label" field of the instruction mnemonics, which must correspond to a label of an Assembler statement within the currently active section. Relative addresses cannot span section boundaries. The address represented by the label must be on a word boundary. This can be insured by using the ALIGN pseudo instruction. CYBER 180 II Assembler ERS 7.0 CYBER 180 CPU SYMBOLIC MACHINE INSTRUCTIONS 7.6.1.3 RETURN #### 7.6.1.3 REIURN This instruction re-establishes the Stack Frame and "environment" of a previous procedure as defined by the Previous Save Area Pointer. The j and k fields from this instruction are not translated by the hardware. Th values have no effect on the execution of this instruction for which all execution parameters are implicit. The Stack Frame Save Area from which a previous procedure's "environment" is obtained, is addressed by means of the PVA initially contained in Register A2. The RETURN instruction may also require global privilege. Consult the MIGDS for further information. RETURN - (Format = jk Dp Code = 04 Ref# = 117) | + | + | + | |---|-----------|----------| | | operation | argument | | - | RETURN | | 7.6.1.4 PDP This instruction re-establishes the Stack Frame of a previous procedure as defined by the Previous Stack Frame's Save Area. The j and k fields from this instruction are not translated by the hardware. Th values have no effect on the execution of this instruction for which all execution parameters are implicit. The Stack Frame Save Area from which a previous procedure's Stack Frame pointers is obtained, is addressed by means of the PVA initially contained in Register A2. POP - (Format = jk Op Code = 06 Ref# = 118) | + | + | <del></del> | |---|------------|-------------| | | loperation | largument | | • | I POP | • | CYBER 180 II Assembler ERS 7.0 CYBER 180 CPU SYMBOLIC MACHINE INSTRUCTIONS 7.6.1.5 EXCHANGE #### 7.6.1.5 EXCHANGE When executed in Monitor mode, this instruction shall change the processor from monitor process state to job process state. When executed in Job mode this instruction changes the processor from job process state to monitor process state. In addition, the System Call bit in position 10 of the Monitor Condition Register, job process state, is set. The PVA contained in Word 0 (P Register) of the Exchange Package associated with the state from which the exchange is taking place, is updated such that it points to the instruction which would have been executed had the exchange not taken place, i.e., the PVA of the "Exchange" instruction with 2 added to its BN field. The j and k fields from this instruction are not translated and their values have no effect on the execution of this instruction. EXCHANGE - (Format = jk Op Code = 02 Ref# = 120) | + | + | | |---|-----------|----------| | | operation | argument | | • | EXCHANGE | | #### 7.6.1.6 KEYPOINI The Keypoint Instruction allows performance monitoring of programs via the optional Performance Monitoring Facility or via Trap Interrupts. The Keypoint Instruction shall test bit j of the Keypoint Mask Register. The j field, termed the Keypoint Class Number (KCN), shall be used as a bit index into the Keypoint Mask Register. Thus, a KCN or j field of value 4 tests the fifth bit from the left in the Keypoint Mask Register (KMR). CIDER TOO II W226HDIGL EK2 7.0 CYBER 180 CPU SYMBOLIC MACHINE INSTRUCTIONS 7.6.1.6 KEYPOINT a) Keypoint, class j, code equal to (XK) Right plus Q. KEYPOINT - (Format = jkQ Op Code = 81 Ref# = 136) # 7.6.1.7 CMPXA=Compare\_Swap a) Compare (Xk) at (Aj); if not equal, load Xk from (Aj); if equal store (XO) at (Aj); however, if (Aj) locked, branch to P plus 2\*Q. CMPXA - (Format = ikQ Op Code = B4 Ref# = 125) label - byte address of the new location, must be in the same section. A serialization function is performed before this instruction begins and again at its end. Execution of this instruction is delayed until all previous accesses to central memory on the part of this processor are completed. Execution of subsequent instructions is delayed until all central memory accesses due to this instruction are completed. Conceptually, the execution of this "Compare" instruction on the part of a processor results in preventing other processors from accessing any part of the central memory word at the PVA contained in Register Aj between the read and write accesses associated with the execution of this instruction, provided such processors are also executing a "Compare" instruction. With respect to this instruction only, in order to satisfy its "non-preemptive" requirement, the use of 64-bit words consisting entirely of ones in their leftmost 32-bit positions, 00 through 31, is reserved for each processor's implementation of this instruction. CYBER 180 II Assembler ERS 7.0 CYBER 180 CPU SYMBOLIC MACHINE INSTRUCTIONS 7.6.1.8 LBSET-Load Bit 1.0.1.0 FD2E1\_FD3G D1E ### 7.6.1.8 LBSEI-Load Bit a) Load Bit to Xk Right from (Aj) bit indexed by (XO) Right and set bit in central memory. LBSET - (Format = jk Op Code = 14 Ref# = 124) | + | + | | |---|------------|----------| | - | loperation | | | • | LBSET | Xk,Aj,XO | This instruction transfers a single bit into Register Xk Right, bit position 63, from a bit position in central memory. This instruction also clears the Xk Register in its leftmost 63 bit positions, 00 through 62. The bit position in central memory is unconditionally set without changing any other bit positions within the byte or word. No other accesses from any port shall be permitted access to the byte in central memory from the beginning of the read access until the end of the write access which sets the bit within that byte. A serialization function is performed before this instruction begins and again at its ending. Execution of this instruction is delayed until all previous accesses to central memory by this processor are completed. Execution of subsequent instructions by this processor is delayed until all central memory accesses from this instruction are completed. ## 7.6.1.9 IPAGE-Iest Page a) Test Page (Aj) and Set Xk Right. TPAGE - (Format = ik Op Code = 16 Ref# = 126) | + | + | <del> </del> | |---|------------|--------------| | | loperation | argument | | • | TPAGE | • | This instruction shall test for the presence of the page in central memory corresponding to the PVA contained in Register Aj. When this instruction finds the corresponding page in central memory, the "Used" bit in the UM field of the associated Page Descriptor is set, and the Real Memory Address (RMA) translated CYBER 180 II Assembler ERS Rev: F 7.0 CYBER 180 CPU SYMBOLIC MACHINE INSTRUCTIONS 7.6.1.9 TPAGE-Test Page from the PVA contained in Register Aj is transferred to Register Xk Right. When this instruction cannot find the corresponding page in central memory, Register Xk Right is set in bit position 32 and cleared in bit positions 33 through 63. 7.6.1.10 CPYIX-Conv Free Running Counter(IIME) to X a) Copy to Xk from Central Memory Maintenance Register at (Xj) Right. CPYTX - (Format = ik Op Code = 08 Ref# = 132) This instruction shall copy the central memory Maintenance Register specified by the contents of Register Xj into the Xk Register. All 64 bits of the Xk Register shall be cleared before the selected register is copied into it. 7.6.2 LOCAL PRIVILEGED MODE This class of instructions shall be permitted to execute only from segments having either local privileged mode or global privileged mode. If an instruction in the local privileged mode class attempts execution from a segment having neither local nor global privileges, a Privileged Instruction Fault shall be detected, execution of that instruction shall be inhibited, and the corresponding program interruption shall occur. Instructions in the local privileged mode class are executable whenever a processor is executing instructions from a segment whose Segment Descriptor defines that segment as either a local privileged executable segment or a global privileged executable segment. #### CYBER 180 II Assembler ERS 7.0 CYBER 180 CPU SYMBOLIC MACHINE INSTRUCTIONS 7.6.2.1 LPAGE-Load Page Table Index # 7.6.2.1 LPAGE-Load Page Table Index a) Load Page Table Index per (Xi) to Xk Right and Set X1 Right. LPAGE - (Format = jk Op Code = 17 Ref# = 127) | + | -+ | <del>*</del> | |---|------------|--------------| | | loperation | argument | | | ILPAGE | | This local privileged instruction searches the Page Table incentral memory, returns the final index value to Register Xk Right, and sets Register X1 Right according to the results of the search. The entry searched for within the Page Table is defined by the System Virtual Address (SVA) contained in Register Xj. The number of entries searched shall always be transferred to Register X1 Right, bits 33-63, right-justified with zeroes extended. When a Page Descriptor corresponding to the SVA initially contained in Register Xj is found, the index into the Page Table which is associated with that entry shall be transferred right-justified and zero-extended to Register Xk Right, and bit 32 of Register X1 Right shall be set. When the Page Table search terminates as a result of not finding a Page Descriptor which corresponds to the SVA initially contained in Register Xj (whether the termination results from a Continue bit equal to 0 or performing a maximum of 32 comparisons), the index into the Page Table associated with the last entry compared shall be transferred into Register Xk Right and bit 32 of Register X1 Right shall be cleared. ## 7.6.3 GLOBAL PRIVILEGED MODE This class of instructions shall be permitted to execute only from segments having global privileged mode. If an instruction in the global privileged mode class attempts execution from a segment not having global privileges, a Privileged Instruction Fault shall be detected, execution of that instruction shall be inhibited, and the corresponding program interruption shall occur. CYBER 180 II Assembler ERS 7.0 CYBER 180 CPU SYMBOLIC MACHINE INSTRUCTIONS 7.6.3 GLOBAL PRIVILEGED MODE Global privileged mode exists whenever the processor is executing instructions from a segment whose Segment Descriptor defines that segment as a global privileged executable segment. # 7.6.3.1 INIRUPI-Interrupt Processor a) Interrupt Processor per (Xk). INTRUPT - (Format = jk Op Code = 03 Ref# = 122) The execution of this global privileged class instruction sends an external interrupt to one or more processors via their central memory ports. The processors are identified by the central memory port number to which they are connected. The interrupting processor sends the contents of Register Xk to central memory. Central memory: then sends an external interrupt to the processor(s) on those ports whose port numbers correspond to the bit positions which are set within Register Xk. When the interrupting processor has two ports connected to the same memory, a "Switch" selects the port used to transmit the contents of Register Xk to central memory along with the "interrupt" function. When the interrupting processor has two ports connected to independent memories, the state of Bit 33 of Register Xk selects the port used to transmit the contents of Register Xk to central memory along with the "interrupt" function. When Bit 33 is clear, Port 0 is used; when Bit 33 is set, Port 1 is used. A serialization function is performed before this instruction begins execution. That is, execution of this instruction is delayed until all previous central memory accesses on the part of the interrupting processor are complete. #### 7.6.4 MIXED MODE This class of instructions includes those instructions whose mode is dependent on a parameter selection within the instruction. Depending on the value of the parameter, the mode of the instruction is non-privileged, local privileged, global privileged, or monitor. The description of each instruction 7.0 CYBER 180 CPU SYMBOLIC MACHINE INSTRUCTIONS 7.6.4 MIXED MODE defines which parameter selects the mode and how the selection is made. #### 7.6.4.1 BRCR-Branch and Alter Condition Register a) Branch to (P) displaced by 2\*Q and alter Condition Register per ik. BRCR - (Format = jkQ Op Code = 9F Ref# = 134) ``` | label | loperation | largument | label lab ``` label - byte address of the new location. This instruction tests the value of a selected bit in the Condition Register. The j field selects the bit number within the Monitor Condition Register or within the User Condition Register depending on the k field. The k field shall also determine the branch decision and Condition Register bit alteration as follows: - k = 0 or 8, if bit j of the Monitor Condition Register is set, clear it and take a branch exit. - k = 2 or A, if bit j of the Monitor Condition Register is set, take a branch exit. - k = 3 or B, if bit j of the Monitor Condition Register is not set, take a branch exit. - k = 4 or C, if bit j of the User Condition Register is set, clear it and take a branch exit. - k = 6 or E, if bit j of the User Condition Register is set, take a branch exit. - k = 7 or F, if bit j of the User Condition Register is not set, take a branch exit. CYBER 180 II Assembler ERS CIDEN ION II WOJCHDIEL FUN 7.0 CYBER 180 CPU SYMBOLIC MACHINE INSTRUCTIONS 7.6.4.1 BRCR-Branch and Alter Condition Register <u>Monitor and Privileged Mode</u> - Some values of the k field of this instruction shall cause this instruction to be a Monitor or Non-privileged instruction as follows: | | k | | 1 | Mode | |-----|----------------------|--------|---|----------------------------------------------------------------------| | 1 2 | or<br>or<br>or<br>or | 9<br>A | 1 | Monitor<br>Monitor<br>Non-privileged<br>Non-privileged | | | or<br>or<br>or<br>or | DE | 1 | Non-privileged<br>Non-privileged<br>Non-privileged<br>Non-privileged | # 7.6.4.2 CPYSX.CPYXS-Copy\_State\_Registers These instructions provide the means for copying certain state registers to and from X Registers. The state register is addressed by means of the rightmost 8-bits initially contained in Register Xj Right. The address assignments are defined in Table 2.6-1 and the restrictions in Table 2.6-2 of the MIGDS. a) Copy to Xk per (Xi). CPYSX - (Format = ik Op Code = OE Ref# = 130) | + | -+ | + | |---|------------|----------| | | loperation | | | | CPYSX | Xk , X j | This instruction copies the contents of the state register addressed by the contents of Register Xj into Register Xk. This instruction is a non-privileged instruction. ### CYBER 180 II Assembler ERS Rev: F 7.0 CYBER 180 CPU SYMBOLIC MACHINE INSTRUCTIONS 7.6.4.2 CPYSX, CPYXS-Copy State Registers b) Copy from XK per (Xj). CPYXS - (Format = jk Op Code = OF Ref# = 131) | + | -+ | | |---|---------------|----------| | | loperation | argument | | • | <b>ICPYXS</b> | • | This instruction copies the contents of Register Xk into the state register addressed by the contents of Register Xi. 7.6.4.3 PURGE-Purge Buffer Purge Buffer k of Entry per (Xj). a) PURGE - (Format = ik Op Code = 05 Ref# = 138) | + | + | <del></del> | |---|------------|-------------| | | loperation | largument | | • | I PURGE | • | The Purge Buffer instruction invalidates entries in the Map and Cache buffers. The purge may invalidate all entries in a invalidates all entries in a buffer which derive from a given segment, invalidate all entries in a buffer for a given page, or invalidate all entries in a buffer for a given 512 byte block. Register Xj contains the required address information, System Virtual Address (SVA) or Process Virtual Address either (PVA). An SVA contains the Active Segment (ASID) in bits 16 through 31 of Register Xj. A PVA contains the Segment number (SEG) in bits 20 through 31 of Register Xi. Bits 32 through 63 contain the Byte Number (BN) for either an SVA or a PVA. The rightmost 9 bits of the BN are ignored and assumed to be zeros since the smallest purgeable portion of a buffer is a 512 byte page or a 512 byte block of a larger page. Proportionately more rightmost bits of the BN are ignored and assumed to be zero as page size becomes larger than the 512 byte minimum. | 16 | 20 | | 32 | 55<br> | 63 | |-----------|----|-------|----|--------|-----| | 1//////// | ı | SEG I | BN | 1///// | /// | | | • | ASID | BN | 1///// | • | CIDEN TON IT WODEHRIEL END 7.0 CYBER 180 CPU SYMBOLIC MACHINE INSTRUCTIONS 7.6.4.3 PURGE-Purge Buffer The value of k determines the buffer to be purged, the range of entries to be purged, and the type of addressing used to determine the range of entries to be purged. The definition of k follows. - k=0. Purge all entries in Cache which are included in the 512 byte block defined by the SVA in Xj. - k=1, Purge all entries in Cache which are included in the ASID defined by the SVA in Xj. - k=2, Purge all entries in Cache. - k=3. Purge all entries in Cache which are included in the 512 byte block defined by the PVA in Xj. - k=4->7, Purge all entries in Cache which are included in the SEG defined by the PVA in Xj. - k=8, Purge all entries in Map which are included in the page defined by the SVA in Xj. This size of the page involved shall be determined by the contents of the Page Size Mask Register. - k=9, Purge all entries in Map which are included in: the ASID defined by the SVA in Xi. - k=A, Purge all information from the map pertaining to the PTE defined by the PVA in Xj. The size of the page involved shall be determined by the contents of the Page Size Mask Register. - k=B, Purge all information from the MAP pertaining to the SDE defined by PVA in Xj, and to all PTE's included within that segment. - k=C->F, Purge all entries in Map. For k=0, 1, 2, 8->F this instruction is a local privileged instruction. It is non-privileged for all other values of k. #### 7.7 YECIOR INSTRUCTIONS #### 7.7.1 GENERAL DESCRIPTION This class of instructions operate on vectors, that is, sequences of full-word integer or real numbers. These instructions are only implemented on the Cyber 180 Model 990. Attempting to execute a vector instruction on any other processor will result in an Unimplemented Instruction condition. # 7.7.2 COMMON ATTRIBUTES OF VECTOR INSTRUCTIONS All vector instructions utilize the jkiD instruction format. However, some instructions do not use all operand fields. In CYBER 180 II Assembler ERS 7.0 CYBER 180 CPU SYMBOLIC MACHINE INSTRUCTIONS 7.7.2 COMMON ATTRIBUTES OF VECTOR INSTRUCTIONS general, the J operand either is an A register which points to a source vector, or is an X register which contains a value which is turned into a vector by "broadcasting" or repeating the value the necessary number of times. The K operand is an A register which points to the destination vector. The I operand is normally a second source vector, but is used differently by some instructions. All addresses used by vector instructions must point to a word boundary, or an Address Specification error will result. In the instruction descriptions that follow, V(Aj) represents either the vector addressed by Aj, or the broadcast vector created from the value in Xj. The D field contains the length of the vector, when non-zero. It must be an positive integer less than or equal to 512. This is the size of the vector in words. When the rightmost ten bits of the D field are zero, X1 Right specifies the length of the vector. When X1 Right is negative, an Instruction Specification error is recorded. When X1 Right is greater than 512, 512 is used for the size of the vector. When the rightmost ten bits of the D field are greater than 512, an Instruction Specification is recorded. The leftmost bit of the D field is set by the Assembler when the J operand is an X register, to indicate that broadcasting shall take place. - 7.7.3 INTEGER VECTOR ARITHMETIC - 7.7.3.1 ADDXY-Add\_Integer\_Vectors - a) Integer vector sum, V(Ak) replaced by V(Aj) plus V(Ai). ADDXV - ( Format = jkiD Dp Code = 44 Ref# = 172) | + | + | | |---|-----------|---------------------------| | • | operation | argument | | 1 | ADDXV | Ak,Aj,Ai,D<br> Ak,Xj,Ai,D | The first form of this instruction adds each word in the vector pointed to by Aj to the corresponding value in the vector pointed to by Ai, storing the result in the vector pointed to by Ak. The second form adds the value in Xj to each word pointed to by Ai, storing the result in the vector pointed to by Ak. ### CYBER 180 II Assembler ERS Rev: F 7.0 CYBER 180 CPU SYMBOLIC MACHINE INSTRUCTIONS 7.7.3.2 SUBXV-Subtract Integer Vectors ### 7.7.3.2 SUBXY-Subtract Integer Vectors a) Integer vector difference, V(Ak) replaced by V(Aj) minus V(Ai). SUBXV - ( Format = ikiD Dp Code = 45 Ref# = 173) | 1 | label | operation | argument | |---|-------|-----------|---------------------------| | 7 | | SUBXV | Ak,Aj,Ai,D<br> Ak,Xj,Ai,D | In the first form, each value in the vector pointed to by Ai is subtracted from its corresponding value in the vector pointed to by Ai. The results are stored in the vector pointed to by Ak. In the second form, the values pointed to by Ai are subtracted from the value in Xi. #### 7.7.4 INTEGER VECTOR COMPARISON The following four instructions compare corresponding elements of two vectors. The results are stored in the vector indicated by Ak. If the compare is true, bit 0 of the corresponding word in V(Ak) is set and bits 1 through 63 are cleared. If the compare is false, bits 0 through 63 are cleared. If the second form is used, where Xi is specified, each value in V(Ai) is compared to the value in Xi. The following example shows the results in V(Ak) after the instruction is executed. CMPEQV A9, A7, A8, 3 ## 7.7.4.1 CMPEQY-Integer Vector Comparison - Equal a) Integer vector compare, V(Ak) replaced by V(Aj) equal to V(Ai). ### CYBER 180 II Assembler ERS Rev: F 7.0 CYBER 180 CPU SYMBOLIC MACHINE INSTRUCTIONS 7.7.4.1 CMPEQV-Integer Vector Comparison: - Equal CMPEQV - ( Format = jkiD Op Code = 50 Ref# = 176) | llabel | loperation | argument | |--------|------------|---------------------------| | | I CMPEQV | Ak,Aj,Ai,D<br> Ak,Xj,Ai,D | 7.7.4.2 CMPLIV-Integer\_Vector\_Comparison\_= Less\_Ihan a) Integer vector compare, V(Ak) replaced by V(Ai) less than V(Ai). CMPLTV - ( Format = ikiD Op Code = 51 Ref# = 177) | 4 | | | | |----------|-------|-----------|---------------------------| | - | label | operation | • | | A. 10000 | 1 | CMPLTV | Ak,Aj,Ai,D<br> Ak,Xj,Ai,D | 7.7.4.3 CMPGEV=Integer\_Vector\_Comparison\_=\_Greater\_Ihan\_Or\_Equal Integer vector compare, V(Ak) replaced by V(Aj) greater than or equal to V(Ai). CMPGEV - ( Format = jkiD Op Code = 52 Ref# = 178) | 4 | <br> | | |---|-----------|----------| | | operation | argument | | 1 | CMPGEV | • | 7.7.4.4 CMPNEY-Integer\_Vector\_Comparison\_=\_Not\_Equal a) Integer vector compare, V(Ak) replaced by V(Ai) not equal to V(AI). CMPNEV - ( Format = jkiD Op Code = 53 Ref# = 179) ### CYBER 180 II Assembler ERS 7.0 CYBER 180 CPU SYMBOLIC MACHINE INSTRUCTIONS 7.7.4.4 CMPNEV-Integer Vector Comparison - Not Equal light longertion longument | the state of s | loperation | largument | |--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------|---------------------------| | | CMPNEV | Ak,Aj,Ai,D<br> Ak,Xj,Ai,D | 7.7.5 SHIFT VECTOR CIRCULAR a) Shift vector circular, V(Ak) replaced byV(Aj), direction and count per V(Aj). SHFV - ( Format = ikiD Op Code = 4D Ref# = 180) | 1 | label | operation | largument | |---|-------|-----------|---------------------------| | 1 | 1 | SHEV | Ak,Aj,Ai,D<br> Ak,Xj,Ai,D | This instruction performs a left circular shift on each element of V(Ai), as directed by the corresponding element of V(Aj), storing the results in V(Ak). The shift count for each element of V(Ai) is taken form the rightmost 8 bits of the corresponding element of V(Aj) and is interpreted as follows: The sign-bit in the leftmost position of the 8-bit shift count shall determine the direction of the shift. When the shift count is positive (sign bit of zero), this instruction shall left shift. When the shift count is negative (sign bit of one), this instruction shall right shift. Shifts shall be from 0-63 bits left and from 1-64 bits right. Based on an 8-bit signed 2's complement shift count, these shifts are as follows: 7.0 CYBER 180 CPU SYMBOLIC MACHINE INSTRUCTIONS 7.7.5 SHIFT VECTOR CIRCULAR When these interpretations of the shift count result in an actual shift count of zero, the instruction transfers the element of V(Ai) to the corresponding element of V(Ak) with no shift. When broadcast of V(Aj) is selected and j=0, the contents of the XO register shall be interpreted as consisting entirely of zeros. 7.7.6 LOGICAL VECTORS # 7.7.6.1 IORY-Inclusive\_Or\_Yectors a) Logical vector sum, V(Ak) replaced by V(Aj) OR V(Ai). IORV - (Format = jkiD Op Code = 48 Ref# = 181) | 1 | label | operation | argument | |---|-------|-----------|---------------------------| | | | IORV | Ak,Aj,AI,D<br> Ak,Xj,AI,D | # 7.7.6.2 XORY-Exclusive Or Vectors a) Logical vector difference, V(Ak) replaced by V(Aj) XOR V(Ai). XORV - ( Format = ikiD Op Code = 49 Ref# = 182) | llabel | loperation | t<br> argument | |--------|------------|---------------------------| | Ì | IXORV | Ak,Aj,Ai,D<br> Ak,Xj,Ai,D | ## 7.7.6.3 ANDY-Logical And Vectors a) Logical vector product, V(Ak) replaced by V(Aj) AND V(Ai). ANDV - ( Format = jkiD Op Code = 4A Ref# = 183) | + | + | + | |---|------------|----------------------------| | | loperation | largument | | | ANDV | IAK,Aj,Ai,D<br>IAK,Xj,Ai,D | ### CYBER 180 II Assembler ERS 7.0 CYBER 180 CPU SYMBOLIC MACHINE INSTRUCTIONS 7.7.7 CONVERT VECTORS - 7.7.7 CONVERT VECTORS - 7.7.7.1 CNIEY-Convert Vector From Integer to Float - a) Convert vector, floating point V(Ak) formed from integer V(Ai). CNIFY - ( Format = jkiD Op Code = 4B Ref# = 184) | + | -+ | . + | |--------|------------|----------| | llabel | loperation | argument | | 1 | CNIFV | lak,aj,D | | 1 | CNIFV | lak,Xj,D | - 7.7.7.2 CNIEY-Convert Vector From Eloat to Integer - a) Convert vector, integer V(Ak) formed from floating point V(Aj). CNFIV - ( Format = jkiD Dp Code = 4C Ref# = 185) | + | <b>+</b> | | |---|------------|---------------------| | | loperation | largument | | İ | ICNFIV | Ak,Aj,D<br> Ak,Xj,D | - 7.7.8 FLOATING POINT VECTOR ARITHMETIC - 7.7.8.1 ADDE-Eloating Point Vector Sum - a) Floating point vector sum, V(Ak) replaced by V(Ai) plus V(Ai). ADDFV - ( Format = jkiD Op Code = 40 Ref# = 186) | 4 | A | | |-------|-----------|---------------------------| | label | operation | • | | * | ADDFV | Ak,Aj,Ai,D<br> Ak,Xj,Ai,D | - 7.7.8.2 SUBEY-Floating Point Vector Difference - a) Floating point vector difference, V(Ak) replaced by V(Aj) ### CYBER 180 II Assembler ERS CIDER 100 11 ASSEMBLEF ERS 7.0 CYBER 180 CPU SYMBOLIC MACHINE INSTRUCTIONS 7.7.8.2 SUBFV-Floating Point Vector Difference minus V(Ai). SUBFV - ( Format = jkiD Op Code = 41 Ref# = 187) | 4 | | | | |---|-------|-----------|----------------------------------| | | label | operation | • | | , | | SUBFV | Ak, Aj, Ai, D<br> Ak, Xj, Ai, D | - 7.7.8.3 MULEY-Eloating Point Vector Product - a) Floating point vector product, V(Ak) replaced by: V(Aj) times V(Ai). MULFV - ( Format = jkiD Op Code = 42 Ref# = 188) - 7.7.8.4 DIVEY-Eloating Point Vector Quotient - a) Floating point vector quotient, V(Ak) replaced by V(Aj) divided by V(Ai). DIVFV - ( Format = jkiD Op Code = 43 Ref# = 189) | **** | | | |------|-----------|---------------------------| | | operation | argument | | 1 | DIVFV | Ak,Aj,Ai,D<br> Ak,Xj,Ai,D | - 7.7.9 FLOATING POINT VECTOR SUMMATION - 7.7.9.1 SUMEY-Floating Point Vector Summation - a) Floating point vector summation, Xk replaced by summation of elements in V(Ai). SUMFV - ( Format = jkiD Op Code = 57 Ref# = 190) CYBER 180 II Assembler ERS CINCL TOO II WIREHALD DEED TO 7.0 CYBER 180 CPU SYMBOLIC MACHINE INSTRUCTIONS 7.7.9.1 SUMFV-Floating Point Vector Summation Terror John V. Foreing Former Vector Summation | + | + | ***** | - | |---|------------|----------------------|---| | | loperation | argument | , | | • | 7 | Xk,Ai,D Merge Vector | • | ## 7.7.9.2 MRGY-Merge Vector a) Merge vector, V(Ak) partially replaced by V(Aj) per mask V(Ai). MRGV - ( Format = $ikiD \oplus Code = 54 Ref# = 191$ ) | + | | **** | |--------|------------|---------------------------| | llabel | loperation | largument | | 1 | IMRGV | Ak,Aj,Ai,D<br> Ak,Xj,Ai,D | This instruction replaces the first element of V(Ak) with the first element of V(Aj) if bit 0 is set in the first element of V(Ai). If bit 0 is clear, the first element of V(Ak) is left unchanged. This operation in repeated for successive elements until the required number of operations has been performed. #### 7.7.10 GATHER AND SCATTER VECTOR ## 7.7.10.1 Gather\_Vector a) Gather vector, V(Ak) replaced by gathered V(Aj) with interval Xi. GTHV - (Format = ikiD Op Code = 55 Ref# = 192) | label | loperation | argument | |-------|------------|----------------------------| | | IGTHV | lak,aj,Xi,D<br>lak,Xj,Ai,D | This instruction obtains the first element from V(Aj) and stores it as the first element of V(Ak). The second element to be stored in V(Ak) is taken from the address formed by adding the rightmost 32 bits of Xi, shifted left three places with zero fill, to the rightmost 32 bits of Aj. Successive elements in V(Ak) are taken from the address formed by adding the rightmost 32 bits of Xi, shifted left three places with zero fill, to the rightmost 32 bits of the previous address. The Nth Rev: F 7.0 CYBER 180 CPU SYMBOLIC MACHINE INSTRUCTIONS 7.7.10.1 Gather Vector (1,2,3,...,n,...) element of V(Ak) is replaced by V(Aj) whose address is (Aj)+8\*(n-1)\*(Xi). The contents of register Xi are not altered by the execution. Thus, contiguous vector V(Ak) is formed by gathering elements from V(Ai) at interval Xi. ## 7.7.10.2 Scatter\_Vector Scatter vector, V(Ak) replaced by scattered V(Aj) with a) interval Xi. SCTV - ( Format = jkiD Op Code = 56 Ref# = 193) | llabel | loperation | The state of s | |--------|------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | | ISCTV | łak,Aj,Xi,D<br>łak,Xj,Ai,D | This instruction obtains the first element from V(Aj) and stores it as the first element of V(Ak). The second contiquous element from V(Aj) is stored into V(Ak) at the address formed by adding the rightmost 32 bits of Xi, shfited left three places with zero fill, to the rightmost 32 bits of Ak. Successive elements from V(Aj) are stored into the addresses formed by adding the rightmost 32 bits of Xi, shifted left three places with zero fill, to the rightmost 32 bits of the prevous address. The Nth $(1,2,3,\ldots,n,\ldots)$ element of V(Ai) is stored into V(Ak)at $(Ak)+8 \Rightarrow (n-1) \Rightarrow Xi$ . Thus, the contiguous elements from V(Aj) are scattered in V(Ak) at interval Xi. 8.0 CYBER 180 ASSEMBLER SYMBOLIC IOU INSTRUCTIONS #### 8.0 CYBER\_180\_ASSEMBLER\_SYMBOLIC\_IOU\_INSTRUCTIONS #### 8.1 SYMBOLIC NOTATION The label field of a symbolic machine instruction optionally contains a symbol. If there is a label present, it is assigned the value of the current location counter. The operation field of a symbolic machine instruction contains the instruction mnemonic which is a pre-defined three or four character name. The first two characters generally describe the function to be performed (ie. data transmission, arithmetic, etc.). The third character indicates the addressing mode used. And if there's a fourth character this indicates it's a "long" machine instruction using a 16-bit operand rather than a 12-bit operand. The argument field of a symbolic machine instruction contains one or two subfields. Each subfield contains an absolute or relocatable expression that reduces to a 6-bit, 12-bit or 18-bit value. An optional comment field may follow the last subfield of the argument field. A comment must begin with the period (.) character. ## 8.2 IOU\_MACHINE\_INSTRUCTION\_EDRMAIS All IOU instructions are represented in one of four formats. Two of these use a single 16-bit word and the other two use two consecutive 16-bit words. These formats are shown below. #### 16-bit Formats | 8 | 5 2 | | 5<br>8 | | 6<br>3 | |---------|-----|---|--------|---|--------| | la 10 0 | 0 | f | | đ | | | | | | | | | | lg 10 0 | | f | | | | \*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\* 8.0 CYBER 180 ASSEMBLER SYMBOLIC IOU INSTRUCTIONS 8.2 IOU MACHINE INSTRUCTION FORMATS. ## 32-bit Formats | 4 5<br>8 2 | | 5<br>8 | | 6 3 | |-------------|---|---------|---|-----| | lg 10 0 0 1 | f | | d | | | 10 0 0 0 1 | | m | | | | • | | | | | | tt | f | <br> s | С | + | | 10 0 0 0 1 | | m | | 1 | The following field descriptions apply to both instruction formats: - f 6-bits the least significant 6 bits of the 7 bit operation code. - d 6-bits an operand, part of an operand, or an address specification depending upon the instruction. - c 5-bits a channel number. - m 12-bits part of an operand, an address specification or an I/O function code depending upon the instruction. - g 1-bit the most significant bit of the 7 bit operation code; g controls the width of the value read or written from IOU memory. If g is o, the operand is 12 bits; if g is one the operand is 16 bits. - s 1-bit a sub-operation code used with certain I/O instructions. - 0 unused bits which should be set to zero. R.O. CYRED 180 ASSEMBLED SYMBOLIC TOU INSTRUCTIONS 8.0 CYBER 180 ASSEMBLER SYMBOLIC IOU INSTRUCTIONS 8.3 IOU ADDRESS MODES #### 8.3 IOU\_ADDRESS\_MODES IOU instruction operands are determined by the address mode of the instruction. The 16-bit or 32-bit instruction format provide for 5, 6, 12, 16 or 18 bit operands and 6 or 12 bit addresses. #### 8.3.1 NO-ADDRESS MODE (N) The no-address mode used the d-field directly as a 6-bit operand. #### 8.3.2 CONSTANT MODE (C) The constant mode uses the d-field and the m-field directly as an 18-bit operand. The d-field contains the most significant 6 bits and the m-field contains the least significant 12 bits. #### 8.3.3 DIRECT MODE (D) The direct mode uses the d-field as the 6-bit address of a 12 or 16 bit operand in memory. #### 8.3.4 INDIRECT MODE (I) The indirect mode uses the d-field as the 6-bit address of a word in memory that is used as the address of a 12 or 16 bit operand in memory. #### 8.3.5 MEMORY MODE (M) The memory mode uses the d-field and the m-field to specify the address of a 12 or 16 bit operand in memory. If the d-field is zero, the m-field is used as a 12 bit address (bits 52-63). If the d-field is not zero, the d-field is a 6-bit address of a 12-bit index. This index is then added to the m-field to generate the 12-bit address of all the possible IOU memory locations ( 0 to 07777(8)). The 12-bit address is specified by d and m as follows (expressed in octal): | **** | + | | +- | | ++ | |------|---|-----|----|----------|----------------------------------| | 1 | 1 | m=0 | ı | m = 7777 | 10 <m<7777 td="" <=""></m<7777> | | + | + | | +- | | ++ | ### CYBER 180 II Assembler ERS 8.0 CYBER 180 ASSEMBLER SYMBOLIC IOU INSTRUCTIONS 8.3.5 MEMORY MODE (M) | d=0 | 1 | 0 | 1 | o | 1 | m | ı | |-------------------|---|-----|---|------|----|-------|---| | d/=0, (d)=0 | 1 | 0 | 1 | 0 | 1 | m | ı | | d/=0, (d)=7777 | 1 | 0 | 1 | 7777 | 1 | m | 1 | | 1d/=0, 0<(d)<7777 | 1 | (d) | 1 | (d) | 1 | m+(d) | İ | | + | | | | | -+ | | 4 | Note, in the block I/O and central memory access instructions, d has an alternate meaning and is not used in address computation. The first word address for these instructions is gotten directly from m and can reference location 7777(8). #### 8.4 NOMENCLATURE\_USED\_IN\_IOU\_INSTRUCTIONS This is the nomenclature used in the following instruction descriptions. - A Refers to the A-register (arithmetic register). - (A) Refers to the contents of the A-register. - X Refers to one bit field which can be either 0 or 1. - c Refers to channel number. - d Refers to the value of the d-field (no-address mode). - dm Refers to the 18-bit value obtained from the d-field and the m-field (constant mode). - (d) Refers to the contents of the location specified by the d-field (direct mode). - ((d)) Refers to the contents of the location specified by the contents of the location specified by the d-field (indirect mode). - m+(d) Refers to the address specified by the m-field indexed by the contents of the location specified by the d-field. - (m+(d)) Refers to the contents of the location specified by the m-field indexed by the contents of the location specified by the d-field (memory mode). Rev: F 8.0 CYBER 180 ASSEMBLER SYMBOLIC IOU INSTRUCTIONS 8.4 NOMENCLATURE USED IN IOU INSTRUCTIONS - Refers to the P-register (program address register). - R Refers to the R-register (relocation register). - (R) Refers to the contents of the R-register. - Refers to the central memory address formed (R)+(A)from the contents of the R and A registers. ## 8.5 GENERAL IOU INSTRUCTIONS The symbolic machine instructions are divided according to their function and then further divided according to the different addressing modes. ## 8.5.1 BRANCH INSTRUCTIONS - 8.5.1.1 LJM. RJM. UJN. ZJN. NJN. PJN. MJN - a) This instruction is a long jump to the address formed by m+(d). LJM - (Format = fdm Op Code = 0001dm Size = 32 bit) | + | + | | |---|------------|--------| | | loperation | - 1607 | | + | .+ | | | 1 | ILJM | lm,d | If d = 0, then m is not modified. b) This instruction stores the current program address plus two ((P)+2) in the address formed by m + (d). The instruction then does a return jump to m + (d) + 1. RJM - (Format = fdm $\Box$ p Code = 0002dm Size = 32 bit) | + | + | | |---|------------|----------| | | loperation | argument | | - | IRJM | • | If d = 0, then m is not modified. | CYBER 180 II Assembler ERS | CY | 'BFR | 180 | TT | ASSE | mbler | FRS | |----------------------------|----|------|-----|----|------|-------|-----| |----------------------------|----|------|-----|----|------|-------|-----| 8.0 CYBER 180 ASSEMBLER SYMBOLIC IOU INSTRUCTIONS 8.5.1.1 LJM, RJM, UJN, ZJN, NJN, PJN, MJN c) This instruction causes an unconditional jump forward or backward as specified by d. UJN - (Format = fd Op Code = 0003d Size = 16 bit) | + | + | • | |---|------------|----------| | | loperation | argument | | • | IUJN | | d) If (A) is zero, then this instruction causes a branch forward or backward as specified by d. ZJN - (Format = fd Op Code = 0004d Size = 16 bit) | + | + | <del> </del> | |--------|-----|--------------| | llabel | . , | argument | | | _ | ld | e) If (A) is non-zero, then this instruction causes a jump to a location either forward or backward as specified by d. NJN - (Format = fd Dp Code = 0005d Size = 16 bit) | + | + | | |---|-----------|---------| | | operation | | | • | INJN | t<br>ld | f) If (A) is positive, then this instruction causes a jump to a location either forward or backward as specified by d. PJN - (Format = fd Op Code = 0006d Size = 16 bit) | + | + | | |--------|-----|----------| | llabel | - • | argument | | • | PJN | • | ### CYBER 180 II Assembler ERS Rev: F 8.0 CYBER 180 ASSEMBLER SYMBOLIC IOU INSTRUCTIONS 8.5.1.1 LJM, RJM, UJN, ZJN, NJN, PJN, MJN g) If (A) is negative, then this instruction causes a jump to a location either forward or backward as specified by d. MJN - (Format = fd Op Code = 0007d Size = 16 bit) | llabel | loperation | argument | |--------|------------|----------| | • | NLMI | • | 8.5.2 SHIFT INSTRUCTION The SHN instruction shifts the content of the A register either right open-ended or left circularly as specified by the d-field. If the most significant bit of the d field is zero, then the content of the A register shifts circularly to the left. If the most significant bit in the d field is one, the content of A shifts open-ended to the right. 8.5.2.1 SHN a) Shift (A) by + (left) or - (right) d bits. SHN - (Format = fd Op Code = 0010d Size = 16 bit) If there's a d-field of 0 or 77(8), then no shifting takes place. . . . . . . 8.5.3 LOAD AND STORE INSTRUCTIONS This sub-group of instructions is responsible for transferring 6-bit, 12-bit, 16-bit or 18-bit values either to or from the IDU A register or memory. When a LDAD instruction is executed any remaining upper bits of the A register are cleared, except for the LCN instruction where the remaining bits are set to one. When a STORE instruction is executed, the contents of the A register are not altered. ## CYBER 180 II Assembler ERS CIDER 100 11 ASSEMBLET ERS REV+ F 8.0 CYBER 180 ASSEMBLER SYMBOLIC IOU INSTRUCTIONS 8.5.3.1 LDN, LCN, LDC - LOAD bits by NO ADDRESS and CONSTANT - 8.5.3.1 LDN. LCN. LDC LOAD bits by NO ADDRESS and CONSIANI - a) Load bits 58-63 of the A register from d-field; bits 46-57 of A are cleared. LDN - (Format = fd Op Code = 0014d Size = 16 bit) | + | + | | |---|------|--------------| | | - 4 | on largument | | 1 | ILDN | d | - b) Load bits 58-63 of the A register with the bit by bit complement of the d-field; bits 46-57 are set to one. - LCN (Format = fd Op Code = 0015d Size = 16 bit) | + | + | | |---|------|-------------| | | • | n largument | | 1 | ILCN | • | - c) Load A register with 18-bit operand from d-field and m-field. - LDC (Format = fdm Op Code = 0020dm Size = 32 bit) | + | + | | |---|------------|----------| | | loperation | argument | | • | ILDC | • | NOTE: There are no corresponding STORE instructions using the NO-ADDRESS or CONSTANT modes. - 8.5.3.2 LDD. LDDL. SID. SIDL LOAD/SIGRE bits by DIRECT mode - a) Load A register with a 12-bit quantity (short form) from (d). - LDD (Format = fd Op Code = 0030d Size = 16 bit) | llabel | loperation | argument | |--------|------------|----------| | • | ILDD | • | | (1 | YRFR | 180 | TT | Assembler ERS | |----|------|-----|----|---------------| | • | DEA | 100 | 11 | ASSEMPTET EVS | Rev: F 8.0 CYBER 180 ASSEMBLER SYMBOLIC IOU INSTRUCTIONS 8.5.3.2 LDD, LDDL, STD, STDL - LOAD/STORE bits by DIRECT mode b) Load A register with 16-bit quantity (long form) from (d). LDDL - (Format = fd Op Code = 1030d Size = 16 bit) | + | + | | |--------|------------|--------------| | llabel | loperation | argument | | | | <del>-</del> | | 1 | ILDDL | <b>1</b> d | c) Store the 12-bit quantity (short form) from A register into STD - (Format = fd Op Code = 0034d Size = 16 bit) | label | loperation | eur eur | |-------|------------|---------| | • | | t | d) Store the 16-bit quantity (long form) from A register into STDL - (Format = fd Op Code = 1034d Size = 16 bit) | + | + | | |---|-----------|----------| | | operation | argument | | • | ISTOL | | - 8.5.3.3 LDI. LDIL. SII. SIIL LOAD/SIORE bits by INDIRECT mode - a) Load A register with 12-bit quantity (short form) from ((d)). LDI - (Format = fd Op Code = 0040d Size = 16 bit) | llabel | loperation | | |--------|------------|---| | • | LDI | d | #### CYBER 180 II Assembler ERS CIDEK TOO II ASSEMBLEE EKS 8.0 CYBER 180 ASSEMBLER SYMBOLIC IOU INSTRUCTIONS 8.5.3.3 LDI, LDIL, STI, STIL - LOAD/STORE bits by INDIRECT mode b) Load A register with 16-bit quantity (long form) from ((d)). LDIL - (Format = fd Op Code = 1040d Size = 16 bit) | + | | | |---|-----------|------| | · | operation | 1948 | | 1 | ILDIL | t | c) Store 12-bit quantity (short form) from A register into ((d)). STI - (Format = fd Op Code = 0044d Size = 16 bit) | + | | <u></u> | |---|------------|-------------| | | loperation | 4.5 | | + | | <del></del> | | • | ISTI | ld . | d) Store 16-bit quantity (long form) from A register into ((d)). STIL - (Format = fd Op Code = 1044d Size = 16 bit) | + | | + | |---|------------|-------------| | | loperation | Tor | | + | + | <del></del> | | 1 | ISTIL | 1d | 8.5.3.4 LDM. LDML. SIM. SIML - LDAD/SIDRE bits by MEMORY mode The address for the operand in these instructions is formed in the following manner: if the d-field is zero, the m-field contains the operand; if the d-field is not zero, the m-field is added to the least significant 12 bits of (d) in ones complement mode. ### CYBER 180 II Assembler ERS Rev: F 8.0 CYBER 180 ASSEMBLER SYMBOLIC IOU INSTRUCTIONS 8.5.3.4 LDM, LDML, STM, STML - LOAD/STORE bits by MEMORY mode a) Load 12-bit operand (short form) from memory into A register. LDM - (Format = fdm Op Code = 0050dm Size = 32 bit) | + | -+ | | |---|------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | | loperation | The state of s | | 1 | | lm, d | b) Load 16-bit operand (long form) from memory into A-register. LDML - (Format = fdm Op Code = 1050dm Size = 32 bit) | + | | <del></del> | |----|------------|-------------| | | loperation | · · · | | ** | ILDML | † | c) Store 12-bit quantity (short form) from A register into memory. STM - (Format = fdm Op Code = 0054dm Size = 32 bit) | + | + | | |---|-----------|---------------------------------------| | | operation | · · · · · · · · · · · · · · · · · · · | | * | ISTM | m,d | d) Store 16-bit quantity (long form) from A register into memory. STML - (Format = fdm Dp Code = 1054dm Size = 32 bit) ## 8.5.4 ARITHMETIC INSTRUCTIONS These instructions perform integer arithmetic using the A register as one operand and the instruction specifying the other operand. The result is then replaced in the A register. | r | YR | FR | 1 | 80 | TT | As | comb | ler | ERS | |---|----|----|---|----------|------|-----|-----------------------|-----|-------| | ┖ | 10 | | | $\omega$ | .1 1 | A.S | <b>3</b> C## <i>U</i> | 151 | 1.7.3 | Rev: F 8.0 CYBER 180 ASSEMBLER SYMBOLIC IDU INSTRUCTIONS 8.5.4.1 ADN, ADC, SBN - ADD/SUBTRACT by NO ADDRESS and CONSTANT - 8.5.4.1 ADN. ADC. SBN = ADD/SUBTRACT by NO ADDRESS and CONSIANI - a) Add a 6-bit quantity from the d-field to the contents of the A-register. The result remains in the A register. ADN - (Format = fd Op Code = 0016d Size = 16 bit) | + | | - | |---|------------|----| | | loperation | ** | | - | IADN | 1d | b) Add an 18-bit quantity from the d and m fields to the contents of the A register. The result remains in the A register. The d-field contains the 6 highest order bits and the m-field contains the 12 lowest order bits. ADC - (Format = fdm Op Code = 0021dm Size = 32 bit) | + | + | + | |---|------------|----------| | | loperation | argument | | 1 | IADC | | c) Subtract a 6-bit quantity from the d-field from the contents of the A register. The result remains in the A register. SBN - (Format = fd Op Code = 0017d Size = 16 bit) | + | + | | |---|------------|----------| | | loperation | 4.7 | | • | ISBN | t<br> d | - 8.5.4.2 ADD. ADDL SBD. SBDL ADD/SUBIRACI bits by DIRECI mode - a) Add a 12-bit quantity (short form) from (d) to the contents of the A register. The result remains in the A register. ADD - (Format = fd Op Code = 0031d Size = 16 bit) | llabel | operation | argument | |--------|-----------|----------| | - | | ld | | CYBER | 180 | TT | Assemb | ler | FRS | |-------|-----|----|--------|-----|-----| | | | | | | | ridev for it vazembiei eva 8.0 CYBER 180 ASSEMBLER SYMBOLIC IOU INSTRUCTIONS 8.5.4.2 ADD, ADDL, SBD, SBDL - ADD/SUBTRACT bits by DIRECT mode b) Add a 16-bit quantity (long form) from (d) to the contents of the A register. The result remains in the A register. ADDL - (Format = fd Op Code = 1031d Size = 16 bit) | + | | - | | |---|-----------|-----------|--| | | operation | largument | | | • | ADDL | * | | c) Subtract a 12-bit quantity (short form) found in (d) from the contents of the A register. The result remains in the A register. SBD - (Format = fd Op Code = 0032d Size = 16 bit) | + | . + | | |---|------------|----| | | loperation | • | | 4 | | • | | 1 | ISBD | 1d | d) Subtract a 16-bit quantity (long form) found in (d) from the contents of the A register. The result remains in the A register. SBDL - (Format = fd Op Code = 1032d Size = 16 bit) | + | + | <del> </del> | |---|------------|--------------| | | loperation | argument | | * | I SBDL | * | - 8.5.4.3 ADI. ADIL. SBI. SBIL ADD/SUBTRACT bits by INDIRECT - a) Add a 12-bit quantity (short form) from storage to the contents of the A register. The address for the operand is in (d). The result remains in the A register. ADI - (Format = fd Op Code = 0041d Size = 16 bit) | + | | <del> </del> | |---|-----------|--------------| | | operation | argument | | • | ADI | • | CYBER 180 II Assembler ERS 8.0 CYBER 180 ASSEMBLER SYMBOLIC IOU INSTRUCTIONS 8.5.4.3 ADI, ADIL, SBI, SBIL - ADD/SUBTRACT bits by INDIRECT b) Add a 16-bit quantity (long form) from storage to the contents of the A register. The address for the operand is in (d). The result remains in the A register. ADIL - (Format = fd Op Code = 1041d Size = 16 bit) | + | | <del></del> | |---|------------|-------------| | | loperation | largument | | • | IADIL | • | c) Subtract a 12-bit quantity (short form) found in storage from the contents of the A register. The address for the operand is found in (d). The result remains in the A register. SBI - (Format = fd Op Code = 0042d Size = 16 bit) | llabel | loperation | argument | |--------|------------|----------| | • | SBI | • | d) Subtract a 16-bit quantity (long form) found in storage from the contents of the A register. The address for the operand is found in (d). The result remains in the A register. SBIL - (Format = fd Op Code = 1042d Size = 16 bit) | + | + | | |---|------------|----------| | | loperation | argument | | • | ISBIL | • | CYBER 180 II Assembler ERS orden too it wascunter but 8.0 CYBER 180 ASSEMBLER SYMBOLIC IOU INSTRUCTIONS 8.5.4.4 ADM, ADML, SBM, SBML - ADD/SUBTRACT bits by MEMORY mode - 8.5.4.4 ADM. ADML. SBM. SBML ADD/SUBIRACI bits by MEMORY mode - a) Add a 12-bit quantity (short form) from storage to the contents of the A register. The address for the operand is formed by adding 12 bits of the m-field to 12 bits from (d). The result remains in the A register. ADM - (Format = fdm Op Code = 0051dm Size = 32 bit) | + | + | <del>-</del> | |--------|-----------------------------------------|--------------| | llabel | loperation | argument | | + | • • • • • • • • • • • • • • • • • • • • | <del> </del> | | • | IADM | lm,d | If d = 0, the storage address is the m-field. b) Add a 16-bit quantity (long form) from storage to the contents of the A register. The address for the operand is formed by adding 12 bits of the m-field to 12 bits from (d). The result remains in the A register. ADML - (Format = fdm Op Code = 1051dm Size = 32 bit) | + | + | | |---|-----------|----------| | | operation | • | | • | IADML | <br> m,d | c) Subtract a 12-bit quantity (short form) found in storage from the contents of the A register. The address of the operand is formed by adding 12-bits of the m-field to 12-bits from (d). The result remains in the A register. SBM - (Format = fdm Op Code = 0052dm Size = 32 bit) | llabel | operation | argument | |--------|-----------|----------| | * | SBM | • | ## CYBER 180 II Assembler ERS CIBER 180 11 ASSEMBIEF ERS REV: F 8.0 CYBER 180 ASSEMBLER SYMBOLIC IOU INSTRUCTIONS 8.5.4.4 ADM, ADML, SBM, SBML - ADD/SUBTRACT bits by MEMORY mode d) Subtract a 16-bit quantity (long form) found in storage from the contents of the A register. The address of the operand is formed by adding 12-bits of the m-field to 12-bits from (d). The result remains in the A register. SBML - (Format = fdm Op Code = 1052dm Size = 32 bit) | + | + | | |---|------------|----------| | | loperation | argument | | * | ISBML | * | 8.5.5 LOGICAL INSTRUCTIONS .... These instructions perform operations using the A register for one operand and the other operand specified by the instruction. The result remains in the A register. 8.5.5.1 LMN.LMC.LPN.LPC.SCN = NO ADDRESS and CONSIANI modes a) Performs the logical difference (EXCLUSIVE OR) function between the d-field and the least significant 6 bits (58-63) of the A register. The rest of the A register is unchanged. LMN - (Format = fd Op Code = 0011d Size = 16 bit) | + | + | | |---|------------|----------| | | loperation | argument | | • | ILMN | | b) Performs the logical difference (EXCLUSIVE OR) function on an 18-bit operand and the A register. The 18-bit operand is formed with the d-field being the highest order 6 bits and the m-field being the lowest order 12 bits. LMC - (Format = fdm Op Code = 0023dm Size = 32 bit) | + | -+ | * | |-------|------------|-------------| | label | loperation | largument | | + | | <del></del> | | 1 | ILMC | l dm | | CYBER 180 II Assembler ER | ERS | ler | Assemb | 1 | H | 180 | BER | CY | |---------------------------|-----|-----|--------|---|---|-----|-----|----| |---------------------------|-----|-----|--------|---|---|-----|-----|----| Rev: F 8.0 CYBER 180 ASSEMBLER SYMBOLIC IOU INSTRUCTIONS 8.5.5.1 LMN, LMC, LPN, LPC, SCN - NO ADDRESS and CONSTANT modes c) Performs the logical product (LOGICAL AND) function between the d-field and the least significant 6 bits (58-63) of the A register. The rest of the A register is cleared. LPN - (Format = fd Op Code = 0012d Size = 16 bit) | + | | + | |---|------------|----------| | | loperation | argument | | i | | ld | d) Performs the logical product (LOGICAL AND) function between an 18-bit operand and the A register. The 18-bit operand is formed with the d-field being the highest order 6 bits and the m-field being is the lowest order 12 bits. LPC - (Format = fdm Op Code = 0022dm Size = 32 bit) | | + | | |----------|------|----------| | l labe l | * | argument | | • | ILPC | | e) Performs a selective clear function on the least siginificant 6 bits (58-63) of the A register where corresponding bits of the d-field are set to one (ie. clears bits 58-63 of A if the corresponding bit in the d-field is set to one). The rest of the A register is unchanged. SCN - (Format = fd Op Code = 0013d Size = 16 bit) | + | + | <del> </del> | |-----|------------|--------------| | • | loperation | argument | | · • | ISCN | • | # CYBER 180 II Assembler ERS 8.0 CYBER 180 ASSEMBLER SYMBOLIC IOU INSTRUCTIONS 8.5.5.2 LMD, LMDL, LPDL - Instructions using DIRECT mode O E E 3 140 1405 1005 - Inches Alies with DIRECT and - 8.5.5.2 LMD. LMDL. LPDL Instructions using DIRECT mode - a) Performs the logical difference (EXCLUSIVE OR) with 12-bit quantity (short form) from (d) and the A register. The highest order 6 bits of the A register are unchanged. LMD - (Format = fd Op Code = 0033d Size = 16 bit) | + | + | + | |-------|---|-----------| | label | * | largument | | - T | | ld | b) Performs the logical difference (EXCLUSIVE OR) with 16-bit quantity (long form) from (d) and the A register. Bits 46-47 of the A register are unchanged. LMDL - (Format = fd Op Code = 1033d Size = 16 bit) | + | + | | |-------|--------|----------| | label | | argument | | • | ILMOL: | | c) Performs the logical product (LOGICAL AND) function with 16-bit quantity (long form) from (d) and the A register. Bits 46-47 of the A register are cleared by this operation. LPDL - (Format = fd Op Code = 1022d Size = 16 bit) | + | + | | |---|-----------|----------| | | operation | argument | | • | ILPDL | | CYBER 180 II Assembler ERS 8.0 CYBER 180 ASSEMBLER SYMBOLIC IOU INSTRUCTIONS 8.5.5.3 LMI, LMIL, LPIL - Instructions using INDIRECT mode 8.5.5.3 LMI. LMIL. LPIL - Instructions using INDIRECT mode a) Performs the logical difference (EXCLUSIVE OR) function on 12-bit quantity (short form) from storage and the A register. The address for the operand is in (d). The rest of the A register is unchanged. LMI - (Format = fd Op Code = 0043d Size = 16 bit) | label | loperatio | n largument | |-------|-----------|-------------| | 1 | ILMI | • | b) Performs the logical difference (EXCLUSIVE OR) function on 16-bit quantity (long form) from storage and the A register. The address of the operand is in (d). Bits 46-47 of the A register are unchanged. LMIL - (Format = fd Op Code = 1043d Size = 16 bit) | + | + | | |---|------------|----------| | | loperation | argument | | • | ILMIL | • | c) Performs the logical product (LOGICAL AND) function on a 16-bit quantity (long form) from storage and the register. The address of the operand is in (d). Bits 46-47 of the A register are cleared by this operation. LPIL - (Format = fd Op Code = 1023d Size = 16 bit) | + | + | <del> </del> | |---|------------|--------------| | | loperation | argument | | | ILPIL | | CYBER 180 II Assembler ERS Rev: F 8.0 CYBER 180 ASSEMBLER SYMBOLIC IOU INSTRUCTIONS 8.5.5.4 LMM, LMML, LPML: Instructions using MEMORY mode 8.5.5.4 LMM. LMML. LPML = Instructions using MEMORY mode a) Performs the logical difference (EXCLUSIVE DR) function on a 12-bit quantity (short form) from storage and the A register. The address for the operand is formed by adding the m-field to 12 bits of (d). The rest of the A register remains unchanged. LMM - (Format = fdm Op Code = 0053dm Size = 32 bit) | + | + | | |---|------|--------------| | | , | on largument | | 1 | ILMM | · | If d = 0, then the m-field is the address for the operand. b) Performs the logical difference (EXCLUSIVE DR) function on a 16-bit quantity (long form) from storage and the A register. The address for the operand is formed by adding the m-field to 12 bits of (d). Bits 46-47 of the A register remain unchanged. LMML - (Format = fdm Op Code = 1053dm Size = 32 bit) If d = 0, then the m-field is the address for the operand. 8.0 CYBER 180 ASSEMBLER SYMBOLIC IOU INSTRUCTIONS 8.5.5.4 LMM, LMML, LPML - Instructions using MEMORY mode c) Performs the logical product (LOGICAL AND) function on a 16-bit quantity (long form) from storage and the A register. The address for the operand is formed by adding the m-field to 12 bits of the (d). Bits 46-47 of the A register are cleared by this operation. LPML - (Format = fdm Op Code = 1024dm Size = 32 bit) | + | | | |---|------------|-----------| | - | loperation | largument | | 1 | ILPML | • | If d = 0, then the m-field is the address for the operand. #### 8.5.6 REPLACE INSTRUCTIONS The replace instructions are similar to the arithmetic instructions in that they both use the A register as one operand and the instruction specifies the other. The difference is that both the A register and the contents of the location of the other operand are replaced with the result. If the instruction is the short (ie. 12-bit operand) then the value returned to storage is the 12 lowest ordered bits of the A register with 4 higher ordered zero bits added. If the instruction is the long form (ie. 16-bit operand) then the 16 lowest ordered bits of the A register are returned to storage. Therefore, the A register and the value replaced in storage are not necessarily equal. All arithmetic is done in 18-bit ones complement mode. ## 8.5.6.1 RAD. RADL - REPLACE ADD using DIRECT mode a) Add a 12-bit quantity (short form) from (d) to the A register. RAD - (Format = fd Op Code = 0035d Size = 16 bit) | + | <del>+</del> | + | |--------|--------------|----------| | llabel | • | argument | | | IRAD | | | CYBER | 180 | TT | Assembler | FRS | |-------|-----|----|-----------|-----| | | | | | | older 100 il Maldudie: Fua 8.0 CYBER 180 ASSEMBLER SYMBOLIC IOU INSTRUCTIONS 8.5.6.1 RAD, RADL' - REPLACE ADD using DIRECT mode 8.5.6.1 RAU, RAUL - REPLACE ADD USING DIRECT mode b) Add a 16-bit quantity (long form) from (d) to the A register. RADL - (Format = fd Op Code = 1035d Size = 16 bit) | + | -+ | · | |---|------------|---------------------------------------| | | loperation | · · · · · · · · · · · · · · · · · · · | | + | | + | | 1 | RADL | 1d | - 8.5.6.2 ADD. ADDL. SOD. SODL REPLACE ADD/SUBTRACT ONE using DIRECT - a) Enter 1 into the A register then add the 12-bit quantity (short form) from (d) to the A register. AOD - (Format = fd Op Code = 0036d Size = 16 bit) | + | + | | |---|------|--------------| | | | on largument | | + | IAOD | t | b) Enter 1 into the A register then add the 16-bit quantity (long form) from (d) to the A register. ADDL - (Format = fd Op Code = 1036d Size = 16 bit) | + | + | | |--------|-------|----------| | llabel | • | argument | | • | IADDL | | c) Enter negative 1 into the A register the $% \left( 1\right) =\left( 1\right) +\left( 1\right)$ (short form) from (d) to the A register. SOD - (Format = fd Op Code = 0037d Size = 16 bit) | + | + | | |---|------------|----------| | | loperation | argument | | • | 1500 | | Rev: F 8.0 CYBER 180 ASSEMBLER SYMBOLIC IOU INSTRUCTIONS 8.5.6.2 ADD, ADDL, SDD, SDDL - REPLACE ADD/SUBTRACT ONE using DIRECT d) Decrease the content of (d) by 1 then use 16-bit quantity (long form) from (d) to add to the A register. SODL - (Format = fd Op Code = 1037d Size = 16 bit) | + | + | | |--------|------------|----------| | llabel | loperation | argument | | + | + | | | 1 | ISODL | ld · | - 8.5.6.3 RAI. RAIL REPLACE ADD using INDIRECT mode - a) Add a 12-bit quantity (short form) from storage to the A register. The address for the operand is found in (d). RAI - (Format = fd Op Code = 0045d Size = 16 bit) | + | | <u></u> | |---|------------|---------| | | loperation | 2 | | • | IRAT | t | b) Add a 16-bit quantity (long form) from storage to the A register. This result remains in A and the 16 lowest ordered bits are returned to storage Therefore, the A register and the value returned to storage are not necessarily equal. The address for the operand is found in (d). RAIL - (Format = fd Op Code = 1045d Size = 16 bit) | + | | | |-------|------------|----------| | label | loperation | argument | | + | + | | | 1 | IRAIL | ld | - 8.5.6.4 ADI. ADIL. SDI. SDIL = REPLACE\_ADD/SUBTRACT\_using\_INDIRECT - a) Enter 1 into the A register then add the 12-bit quantity (short form) of the operand in storage. The address for the operand is found in (d). ADI - (Format = fd Op Code = 0046d Size = 16 bit) | + | -+ | · • | |--------|------------|-----------| | llabel | loperation | largument | | | · · | + | ## CYBER 180 II Assembler ERS 8.0 CYBER 180 ASSEMBLER SYMBOLIC IOU INSTRUCTIONS 8.5.6.4 ADI, ADIL, SDI, SDIL - REPLACE ADD/SUBTRACT using INDIRECT > 1 IOA ld b) Enter 1 into the A register then add the 16-bit quantity (long form) of the operand in storage. The address for the operand is found in (d). ADIL - (Format = fd Op Code = 1046d Size = 16 bit) | label | loperation | · · · · · · · · · · · · · · · · · · · | |-------|------------|---------------------------------------| | | AOIL | † | c) Enter negative 1 into the A register then add the 12-bit quantity (short form) of the operand in storage. The address for the operand is found in (d). SOI - (Format = fd Op Code = 0047d Size = 16 bit) | + | + | | | |---|------------|----------|--| | | loperation | argument | | | • | - | ld | | d) Enter negative 1 into the A register then add the 16-bit of the operand in storage. The address for the operand is found in (d). SOIL - (Format = fd Op Code = 1047d Size = 16 bit) | + | + | | |---|-----------|----------| | | operation | argument | | · | ISOIL | | ## CYBER 180 II Assembler ERS Rev: F 8.0 CYBER 180 ASSEMBLER SYMBOLIC IOU INSTRUCTIONS 8.5.6.5 RAM, RAML - REPLACE ADD using MEMORY mode - 8.5.6.5 RAM. RAML REPLACE ADD using MEMORY mode - a) Add a 12-bit quantity (short form) from storage to the A register. The address for the operand is found by adding the m-field to the content of (d). RAM - (Format = fdm Op Code = 0055dm Size = 32 bit) | llabel | loperation | argument | |--------|------------|----------| | • | IRAM | • | If d = 0, then the operand address is the m-field. b) Add a 16-bit quantity (long form) from storage to the A register. The address for the operand is found by adding the m-field to the content of (d). RAML - (Format = fdm Op Code = 1055dm Size = 32 bit) | + | + | + | | |----------------------|-------|-----------|--| | label loperation | | largument | | | • | IRAML | • | | If d = 0, then the operand address is the m-field. - 8.5.6.6 ADM. ADML. SOM. SOML = REPLACE ADD/SUBTRACT ONE using MEMORY mode < - a) Enter 1 into the A register the add the 12-bit quantity (short form) of the operand from storage. The address for the operand is found by adding the m-field to the content of (d). AOM - (Format = fdm Op Code = 0056dm Size = 32 bit) If d = 0, then the operand address is the m-field. CYBER 180 II Assembler ERS Rev: F 8.0 CYBER 180 ASSEMBLER SYMBOLIC IOU INSTRUCTIONS 8.5.6.6 ADM, ADML, SDM, SDML - REPLACE ADD/SUBTRACT DNE using MEMORY mode b) Enter 1 into the A register then add the 16-bit quantity (long form) of the operand from storage. The address for the operand is found by adding the m-field to the contents of (d). AOML - (Format = fdm Op Code = 1056dm Size = 32 bit) | + | -+ | + | |--------|------------|-----------| | llabel | loperation | largument | | | | | | | AOML | lm,d | If d = 0, then the operand address is the m-field. c) Enter negative 1 into the A register then add the 12-bit (short form) of the operand form storage. The address for the operand is found by adding the m-field to the content of (d). SDM - (Format = fdm Op Code = 0057dm Size = 32 bit) | + | | + | |---|-----------|-----------| | | operation | largument | | 1 | · . | lm, d | If d = 0, then the operand address is the m-field. d) Enter negative 1 into the A register then add the 16-bit quantity (long form) of the operand form storage. The address for the operand is found by adding the m-field to the content of (d). SOML - (Format = fdm Op Code = 1057dm Size = 32 bit) If d = 0, then the operand address is the m-field. CYBER 180 II Assembler ERS 8.0 CYBER 180 ASSEMBLER SYMBOLIC IOU INSTRUCTIONS 8.5.7 CENTRAL MEMORY ACCESS INSTRUCTIONS #### 8.5.7 CENTRAL MEMORY ACCESS INSTRUCTIONS The central memory access instructions provide a means for reading and writing central memory to and from IOU memory. The IOU has read access to all of central memory but write and exchange accesses are monitored by the OS Bounds Register. Central memory addressing uses real addresses rather than virtual addresses and these are formed from the contents of the A-register and the R-register. The two types of addressing for these instructions are absolute and relocation. The type of addressing desired is determined by bit 46 of the A register. In all the central memory acess instructions (R) + (A) will mean the following: If bit 46 of the A register is zero, the absolute central memory address is specified by bits 47-63 of the A register. If bit 46 of the A register is one, meaning relocation is desired, 6 zeros are concatenated to the rightmost end of the contents of the R register and this is added to bits 47-63 of (A) forming an absolute central memory address. The OS Bounds Register divides central memory into two regions for dual-state. For write and exchange accesses, a bit in the OS Bounds Register for each PP indicates which region the PP has access to: - A set bit indicates the lower region: PP CM address < OS boundary. - A cleared bit indicates the upper region: OS boundary < PP CM address. Address verification for CM accesses occurs on the following IOU instructions: | 0026 | EXCHANGE JUMP | |------|-----------------------------| | 0062 | CENTRAL WRITE | | 1062 | CENTRAL WRITE | | 0063 | CENTRAL WRITE | | 1063 | CENTRAL WRITE | | 1000 | CENTRAL READ AND SET LOCK | | 1001 | CENTRAL READ AND CLEAR LOCK | | | | ## CYBER 180 II Assembler ERS CLUEN TOO IT WOOMINGLEN END 8.0 CYBER 180 ASSEMBLER SYMBOLIC IOU INSTRUCTIONS 8.5.7.1 LRD, SRD, - LOAD/STORE R Register in IOU Memory - 8.5.7.1 LRD. SRD. LOAD/STORE R Register in IOU Memory - a) Loads 22-bit (R) register from (d) and (d)+1. Bits 46-57 of R are loaded from bits 52-63 of (d)+1 and bits 52-63 of R are loaded from bits 54-63 of (d). - LRD (Format = fd Op Code = 0024d Size = 16 bit) | + | + | | |---|------|--------------| | | • | on largument | | 1 | ILRD | 1 d | If d = 0, then the instruction is a pass. b) Stores the content of the 22-bit R register into (d) and (d)+1. Bits 46-57 of the R register are stored in (d)+1 and bits 36-45 of R are stored in (d). The remaining bits in (d) and (d)+1 are cleared. SRD - (Format = fd Dp Code = 0025d Size = 16 bit) | + | + | | |---|-----------|----------| | | operation | argument | | - | ISRO | • | If d = 0, then the instruction is a pass. ## CYBER 180 II Assembler ERS CIDER 100 11 ASSEMBLET ERS REV. F 8.0 CYBER 180 ASSEMBLER SYMBOLIC IOU INSTRUCTIONS 8.5.7.2 CRD, CRDL, CWD, CWDL - RD/WR CPU Memory, DIRECT mode # 8.5.7.2 CRD. CRDL. CWD. CWDL - RD/WR CPU Memory. DIRECT mode When reading or writing a CM memory word to or from IOU memory; two different packing/unpacking schemes are used depending on if the instruction specifies the long (64 bit) or short (60 bit) form. # PACKING/UNPACKING for short instructions (60 bit value) Central Memory Word | .0 | , | 6 | 2<br>8 | 4<br>0 | 5 | | |------|-------|-------|--------|--------|-------|---| | 1(4) | a(12) | b(12) | c(12) | d(12) | e(12) | i | #### PP MEMORY WORDS | | 8 | 5 | 6 | |-----|--------|-------|---| | đ | 10(4) | a(12) | | | d+1 | 10(4) | b(12) | | | d+2 | 10(4) | c(12) | ! | | d+3 | 0(4) | d(12) | 1 | | d+4 | 1 0(4) | e(12) | 1 | | | · | * | | ## CYBER 180 II Assembler ERS Rev: F 8.0 CYBER 180 ASSEMBLER SYMBOLIC IOU INSTRUCTIONS 8.5.7.2 CRD, CRDL, CWD, CWDL - RD/WR CPU Memory, DIRECT mode PACKING/UNPACKING for long instructions (64 bit value) # Central Memory Word | .0 | | 6 | | 3 2 | | 4<br>8 | | 6<br>3 | |----|-------|---|-------|-----|-------|--------|-------|--------| | 1 | a(16) | 1 | b(16) | 1 | c(16) | ı | d(16) | . 1 | # PP Memory Words | | 8 | | 6 3 | |-----|---|-------|-----| | đ | Ĭ | a(16) | | | d+1 | | b(16) | ! | | d+2 | | c(16) | ! | | d+3 | | d(16) | | a) Reads one central memory word (60 bit word), 4-63, to bits 52-63 of five consecutive IOU memory words. The address for the CM word is specified by (R) + (A). The address for the first IOU memory word is specified by d. CRD - (Format = fd Op Code = 0060d Size = 16 bit) | + | | + | |---|-----------|-------------| | | operation | argument | | + | | <del></del> | | 1 | ICRD | ld | CYBER 180 II Assembler ERS 8.0 CYBER 180 ASSEMBLER SYMBOLIC IOU INSTRUCTIONS 8.5.7.2 CRD, CRDL, CWD, CWDL - RD/WR CPU Memory, DIRECT mode b) Reads one central memory word (64 bit word) to four consecutive iou memory words. The address for the CM word is specified by (R) + (A). The address for the first IOU memory word is specified by d. CRDL - (Format = fd Op Code = 1060d Size = 16 bit) | + | + | <u> </u> | |--------|-------|----------| | llabel | , | argument | | * | ICRDL | | c) Transfers the 12 lowest ordered bits from five consecutive IBU memory words to bits 4-63 of a central memory word (60 bit word). Bits 0-3 are cleared. The address for the CM word is specified by (R) + (A) and is verified against the OS Bounds Register. The address for the first IBU memory word is specified by d. CWD - (Format = fd Op Code = 0062d Size = 16 bit) | + | + | • | |-------|-----|----------| | label | , | argument | | • | · · | ld | d) Transfers the 12 lowest ordered bits from four consecutive IOU memory words to one central memory word (64 bit word). The address for the CM word is specified by (R) + (A) and is verified against the OS Bounds Register. The address for the first IOU memory word is specified by d. CWDL - (Format = fd Op Code = 1062d Size = 16 bit) | + | + | | |---|------------|-----------| | • | loperation | largument | | • | CMDL | • | ## 8.5.7.3 CRM. CRML. CWM. CWML - READ/WRITE CM Blocks After the following instructions are completed A will contain the non-relocated portion of the CM address plus one of the last memory word transferred. Note that if the value of bits 47-63 of A exceeds (2\*\*17)-1, then bit 46 will be toggled and the addressing mode will change from direct addressing to relocation addressing mode. Note also that if CYBER 180 II Assembler ERS 8.0 CYBER 180 ASSEMBLER SYMBOLIC IOU INSTRUCTIONS 8.5.7.3 CRM, CRML, CWM, CWML - READ/WRITE CM Blocks the last CM word transferred has a relative address of 377776(8) and relocation is in affect, the A register will be cleared and the value in A may not point to the last word transferred plus one. a) Transfers bit 4-63 of consecutive central memory words (ie. 60 bit words) to consecutive IOU memory words. The address of the first CM word is specified by (R) + (A), the address of the first IOU memory word is specified by m and the number of CM words transferred is specified by (d). CRM - (Format = fdm Op Code = 0061dm Size = 32 bit) | + | + | | |---|------|-------------| | | | n: argument | | 1 | ICRM | • | b) Transfers consecutive central memory words (64 bit words) to consecutive IOU memory words. The address of the first CM word is specified by (R) + (A), the address of the first IOU memory word is specified by m and the number of CM words transferred is given by (d). CRML - (Format = fdm Op Code = 1061dm Size = 32 bit) | + | + | | |--------|--------|-----------| | llabel | • | largument | | • | I CRMI | | c) Transfers bits 52-63 of consecutive IDU memory words to bits 4-63 of consecutive central memory words (60 bit words). Bits 0-3 are cleared. The address for the first IDU memory word is specified by m, the address for the first CM word is specified by (R) + (A) and is verified against the DS Bounds Register. The number of CM words transferred is given by (d). CWM - (Format = fdm Op Code = 0063dm Size = 32 bit) | llabel | loperation | argument | |--------|------------|----------| | • | ICHM | | CYBER 180 II Assembler ERS 8.0 CYBER 180 ASSEMBLER SYMBOLIC IOU INSTRUCTIONS 8.5.7.3 CRM, CRML, CWM, CWML - READ/WRITE CM Blocks d) Transfers consecutive IOU words to consecutive central memory words (64 bit words). The address for the first IOU word is specified by $m_{\star}$ the address for the first CM word is specified by (R) + (A) and is verified against the DS The number of CM words transferred is Bounds Register. specified by (d). CWML - (Format = fdm Op Code = 1063dm Size = 32 bit) | + | + | <del>-</del> | |---|------------|--------------| | | loperation | argument | | • | ICWML | • | ## 8.5.7.4 RDSL. RDCL = READ\_CM\_and\_SET\_or\_CLEAR\_LDCK A serialization function is performed at the beginning and the end of these instructions. Execution is delayed until all accesses to central memory by the IDu are completed, no other accesses are permitted from the beginning of the read until the end of the write and no execution from other instructions are allowed until all accesses to and from CM from this instruction are completed. a) The LOGICAL OR function is performed between four consecutive IDU memory words and one central memory, word (64 bit word). The result is replaced in the CM word while the original contents of the CM word are replaced in the four IOU words. The address of the first IOU word is specified by d, the address for the CM word is specified by (R) + (A) and is verified against the OS Bounds Register. RDSL - (Format = fd Op Code = 1000d Size = 16 bit) | + | + | + | |---|-----------|-----------| | | operation | largument | | • | IRDSL | | CYBER 180 II Assembler ERS 8.0 CYBER 180 ASSEMBLER SYMBOLIC IOU INSTRUCTIONS 8.5.7.4 RDSL, RDCL - READ CM and SET or CLEAR LOCK b) The LOGICAL AND function is performed between four consecutive IOU memory words and one central memory word (64 bit word). The result is replaced in the CM word while the original contents of the CM word are replaced in the four IOU words. The address for the first IOU word is specified by d, the address for the CM word is specified by (R) + (A) and is verified against the OS Bounds Register. RDCL - (Format = fd Dp Code = 1001d Size = 16 bit) | label | • | Largument | |-------|-------|------------| | | • | tar gument | | 1 | IRDCL | 1d | 8.5.8 INPUT/OUTPUT INSTRUCTIONS There are 26 instructions to control activity on I/O channels. These instructions select an external device, determine if the device is available and ready to transfer data and then transfers data to or from the device. Each PP has a set of external function codes that establishes the mode of operation and also starts and stops data transfer. The devices are also capable of detecting certain errors and they report these to the controlling PP. 8.5.8.1 AJM: SCE: ESJM: IJM: ECJM: EJM: EJM: SEM: CEM: CCE The following instructions are conditional branch instructions, each of which tests for a condition on channel c. When the condition is true the branch to address m occurs and when the condition is false execution continues with the following instruction. The c expression is required. a) Branch to the location specified by m if channel c is active. AJM - (Format = fscm Op Code = 00640cm Size = 32 bit) | + | + | <del>}</del> | |-------|------|--------------| | label | * | argument | | • | IAJM | • | # CYBER 180 II Assembler ERS 8.0 CYBER 180 ASSEMBLER SYMBOLIC IOU INSTRUCTIONS 8.5.8.1 AJM, SCF, FSJM, IJM, FCJM, FJM, EJM, SFM, CFM, CCF b) Branch to location specified by m if the channel c flag is set, otherwise set channel flag and exit. One may unconditionally set the channel flag by setting m to P+2. SCF - (Format = fscm Op Code = 00641cm Size = 32 bit) | + | | · | |---|------|--------------| | | w. | on largument | | • | ISCF | m,c | c) Branch to the location specified by m if the flag for channel c is set. FSJM - (Format = fscm Op Code = 1064Xcm Size = 32 bit) | + | + | | |---|--------------|----------| | | loperation | argument | | + | <del>+</del> | , | | | <b>IFSJM</b> | m,c | d) Branch to the location specified by m if channel c is inactive. IJM - (Format = fscm Op Code = 00650cm Size = 32 bit) | + | + | · | |-------|---|----------| | label | , | argument | | | - | lm,c | e) Branch to the location specified by m if the flag for channel c is clear. FCJM - (Format = fscm Op Code = 1065Xcm Size = 32 bit) | + | + | | |--------|------|----------| | llabel | , | argument | | • | FCJM | | | CYBER | 180 | TT | ASSAM | hler | FRS | |----------------------------------------------|-----|-----|------------|-----------|---------| | <b>*</b> * * * * * * * * * * * * * * * * * * | 1 | 2 1 | M 3 3 5 11 | 127 1 2 2 | 3 5 % F | 8.0 CYRER 180 ASSEMBLER SYMBOLIC TOURINSTRUCTIONS 8.0 CYBER 180 ASSEMBLER SYMBOLIC IOU INSTRUCTIONS 8.5.8.1 AJM, SCF, FSJM, IJM, FCJM, FJM, EJM, SFM, CFM, CCF f) Branch to the location specified by m if channel c is full. FJM - (Format = fscm Op Code = 00660cm Size = 32 bit) | + | + | | |--------|------|----------| | llabel | | argument | | • | IFJM | • | g) Branch to the location specified by m if channel c is empty. EJM - (Format = fscm Op Code = 00670cm Size = 32 bit) | + | -+ | | |---|--------------|----------| | | loperation | argument | | * | <b>I</b> EJM | * | h) Branch to the location specified by m if the channel c error flag is set, and then clear error flag. SFM - (Format = fscm Op Code = 00661cm Size = 32 bit) | + | + | | |---|-----------|----------| | | operation | argument | | • | ISFM | • | i) Branch to the location specified by m if the channel c error flag is clear, and then clear error flag. CFM - (Format = fscm Op Code = 00671cm Size = 32 bit) | llabel | loperation | argument | |--------|------------|----------| | • | CFM | • | ## CYBER 180 II Assembler ERS Rev: F 8.0 CYBER 180 ASSEMBLER SYMBOLIC IOU INSTRUCTIONS 8.5.8.1 AJM, SCF, FSJM, IJM, FCJM, FJM, EJM, SFM, CFM, CCF i) Clear the flag on the channel specified by c. The m-field is required but not used. CCF - (Format = fscm Op Code = 00651cm Size = 32 bit) | + | | | |---|------------|----------| | | loperation | argument | | - | ICCF | * | 8.5.8.2 IAN. DAN - A Register I/O Instructions a) Transfers a word from channel c to bits 48-63 of register A. Bits 46-47 are cleared. The instruction waits for the channel to become active and full before executing. IAN - (Format = fsc Op Code = 00700c Size = 16 bit) | + | + | | |--------|-----|----| | llabel | , | • | | " | IAN | lc | b) Transfers a word from channel c to bits 48-63 of register A. Bits 46-47 are cleared. If the channel is inactive or becomes inactive before becoming full, no transfer takes place and the instruction exits with (A) = 0. IAN - (Format = fsc Op Code = 00701c Size = 16 bit) | 1 | | | |--------|-----------|----------| | * | • | - | | llabel | operation | argument | | + | <b>*</b> | | | 1 | IIAN | 140(8)+c | Note, on these two instructions if a 12-bit external interface is used, bits 48-63 of A are zero. If an 8-bit interface is used, bits 46-55 of A will be zero. CYBER 180 II Assembler ERS 8.0 CYBER 180 ASSEMBLER SYMBOLIC IOU INSTRUCTIONS 8.5.8.2 IAN, DAN - A Register I/O Instructions 0.0.0.2 IAN; DAN = A REGISTER 170 INSTRUCTIONS c) Transfers bits 48-63 of (A) to channel c. The instruction waits for the channel to become active and empty before executing. The content of A is unchanged. DAN - (Format = fsc Dp Code = 00720c Size = 16 bit) | + | | | |-----|------------|----------| | | loperation | argument | | · • | IOAN | • | d) Transfers bits 48-63 of (A) to channel c. If the channel is inactive, than no transfer takes place and the instruction exits. The content of A is unchanged. DAN - (Format = fsc Dp Code = 00721c Size = 16 bit) | + | | <del> </del> | |---|------------|--------------| | | loperation | largument | | 1 | | 140(8)+c | Note, on these two instructions if a 12-bit external interface is used on the channel, bits 48-51 of the channel word are not transmitted and are lost. If an 8-bit interface is used, then bits 48-55 of the channel word are not transmitted and are lost. # 8.5.8.3 IAM. IAPM. DAM. DAPM - BLOCK I/O Instructions - a) Transfers successive words from channel coto consecutive IOU memory words. The address of the first IOU memory word is specified by mand the number of words transferred is specified by (A). Termination can occur one of two ways: - -(A) = 0 or - channel becomes inactive; if this is the cause for termination, the next IOU word is cleared and (A) will contain the difference of the initial value and the number of words transferred. If the channel is initially inactive when the instruction is executed, no transfer takes place, (A) remains unchanged and the IDU word specified by m is set to zero. IAM - (Format = fscm Op Code = 00710cm Size = 32 bit) CYBER 180 II Assembler ERS 8.0 CYBER 180 ASSEMBLER SYMBOLIC IOU INSTRUCTIONS 8.5.8.3 IAM, IAPM, OAM, OAPM - BLOCK I/O Instructions Note, with a 12-bit external interface, bits 48-51 of IOU memory will be zero; With an 8-bit interface, bits 48-55 of IOU memory will be zero. CYBER 180 II Assembler ERS 8.0 CYBER 180 ASSEMBLER SYMBOLIC IOU INSTRUCTIONS 8.5.8.3 IAM, IAPM, DAM, DAPM - BLOCK I/O Instructions - b) Transfers bits 52-63 of successive words from channel c to consecutive IOU memory words. During this transfer, 4 channel words (48 bits) are packed into 3 IOU memory words. (See below.) Bits 48-51 of the channel word is ignored. The address of the first IOU memory word is specified by m and the number of channel words is specified by (A). Termination can occur one of two ways: - (A) = 0; if the number of channel words transferred is not a multiple of 4, then the last IBU word will be zero filled; - channel becomes inactive; IOU words will be zero filled to the next four channel word boundary. If the channel is initially inactive when the instruction is executed, no transfer takes place, (A) remains unchanged and the IOU memory words m, m+1, m+2 are set to 0. #### Channel Words | 4<br>8 | 2 | 6 3 | |--------|--------|------| | (4) | a(1 | 2) | | 1 (4) | b(4) | c(8) | | 1 (4) | 1 d(8) | e(4) | | | f(1 | (2) | | + | + | + | IOU Memory Words | 8 | | 6 | - | 3 | |--------|-----|------|------|------| | a(12 | ) | | 1 60 | 4) [ | | c | (8) | 1 d | (8) | 1 | | l e(4) | 1 | f(12 | ) | Ī | ## CYBER 180 II Assembler ERS 8.0 CYBER 180 ASSEMBLER SYMBOLIC IOU INSTRUCTIONS 8.5.8.3 IAM, IAPM, DAM, DAPM - BLOCK I/O Instructions IAPM -(Format = fscm Op Code = 10710cm Size = 32 bit) | + | + | | |---|------------|-----| | | loperation | - | | | IAPM | m,c | - c) Transfers the contents of consecutive IDU memory words as successive words on channel c. The address of the first IOU word is specified by m and the number of words to be transferred is specified by (A). Termination occurs one of two ways: - (A) = 0 or - channel becomes inactive; if this happens (A) contains the difference between the initial value and the actual number of words transferred. If the channel is initially inactive when the execution begins, no transfer takes place and (A) remains unchanged. DAM - (Format = fscm Dp Code = 00730cm Size = 32 bit) | + | + | <del> </del> | |--------|------|--------------| | llabel | | argument | | • | IOAM | • | Note, if a 12-bit external interface is used, bits 48-51 of the channel word is not transmitted and are lost. If an 8-bit interface is used, bits 48-55 are not transmitted and are lost. CYBER 180 II Assembler ERS 8.0 CYBER 180 ASSEMBLER SYMBOLIC IOU INSTRUCTIONS 8.5.8.3 IAM, IAPM, DAM, DAPM - BLOCK I/O Instructions - d) Transfers consecutive IOU memory words as bits 52-63 of successive words on channel c. During the transfer the contents of 3 IOU words result in 4 channel words (same packing as above). Bits 48-51 of the 16-bit channel word are cleared. The address for the first IOU word is specified by m and the number of channel words transferred is specified by (A). Termination occurs one of two ways: - (A) = 0 or - channel is inactive; if this happens, (A) will contain the difference of its initial value and the number of words actually transferred. If the channel is initially inactive when execution begins, no transfer takes place and (A) remains unchanged. DAPM - (Format = fscm Op Code = 10730cm Size = 32 bit) | + | <b>+</b> | | |--------|----------|----------| | llabel | ` ' | argument | | • | IOAPM | • | - 8.5.8.4 ACN. DCN ACTIVATE/DEACTIVATE I/O Channels - a) Prepares channel c for I/O transfer by setting the channel active. If the channel is active, then the instruction will wait for the channel to become inactive before executing. ACN - (Format = fsc Op Code = 00740c Size = 16 bit) | + | + | | |---|------------|----------| | • | loperation | • | | 1 | IACN | t<br>l c | b) Prepares channel c for I/O transfer by setting the channel active. The instruction will execute regardless to the active/inactive status of the channel. ACN - (Format = fsc Op Code = 00741c Size = 16 bit) | llabel | loperation | argument | |--------|------------|----------| | • | IACN | • | ## CYBER 180 II Assembler ERS 8.0 CYBER 180 ASSEMBLER SYMBOLIC IOU INSTRUCTIONS 8.5.8.4 ACN, DCN - ACTIVATE/DEACTIVATE I/O Channels 8.5.8.4 ACN, UCN - ACTIVATE/DEACTIVATE I/U Channels c) Terminates I/O operations on channel c by setting the channel inactive. If the channel is inactive, the instruction will wait for the channel to become active before executing. DCN - (Format = fsc Op Code = 00750c Size = 16 bit) | + | + | | |---|------------|----------| | | loperation | argument | | • | IDCN | • | d) Terminates I/O operations on channel c by setting the channel inactive. The instruction will execute regardless of the active/inactive status of the channel. DCN - (Format = fsc Op Code = 00751c Size = 16 bit) | + | | <del> </del> | |---|------------|--------------| | | loperation | 10- | | 1 | IDCN | 140(8)+c | Note, on both DCN instructions, if they are executed after an output instruction without waiting for the channel to become empty, the last channel word transferred may be lost. # 8.5.8.5 EAN. ENC - I/O Channel Eunctions a) Transfers bits 48-63 of (A) as a function code to channel c. If the channel is active, the instruction will wait for the channel to become inactive before executing. The content of A remains unchanged. FAN - (Format = fsc Op Code = 00760c Size = 16 bit) | + | + | | |---|-----------|----------| | | operation | argument | | • | FAN | | CYBER 180 II Assembler ERS Rev: F 8.0 CYBER 180 ASSEMBLER SYMBOLIC IOU INSTRUCTIONS 8.5.8.5 FAN, FNC - I/O Channel Functions b) Transfers bits 48-63 of (A) as a function code to channel c. If the channel is active, the function is not transferred and the instruction exits. The content of A remains unchanged. FAN - (Format = fsc Op Code = 00761c Size = 16 bit) | + | + | | |-----|------------|----------| | | loperation | argument | | · · | | 40(8)+c | c) Transfers m as a function code to channel c. If the channel is active, the instruction will wait for the channel to become inactive before executing. FNC - (Format = fscm Op Code = 00770cm Size = 32 bit) | + | + | | |---|------------|---| | | loperation | • | | * | FNC | + | d) Transfers m as a function code to channel c. If the channel is active, the function is not transferred and the instruction exits. FNC - (Format = fscm Op Code = 00771cm Size = 32 bit) | + | + | <del> </del> | |---|-----------|--------------| | | operation | argument | | • | IFNC | • | Note, if a 12-bit external interface is used on the channel bits 48-51 of the function code will not be transferred and are lost. If an 8-bit interface is used, bits 48-55 of the function code m are not transmitted and are lost. . .... . 8.5.9 OTHER IOU INSTRUCTIONS ## CYBER 180 II Assembler ERS OIDEN INV II MIJOHUICI ENI 8.0 CYBER 180 ASSEMBLER SYMBOLIC IOU INSTRUCTIONS 8.5.9.1 EXN, MXN, MAN - EXCHANGE JUMP Instructions 8.5.9.1 EXN. MXN. MAN = EXCHANGE JUMP\_Instructions These instructions provide for IOU programs to control the execution of the CPU in CYBER 170 state. Note, the d-field can be in the range of 0-7. The value of the d-field specifies which processor (CPU) the exchange jump will interrupt. a) Perform an unconditional exchange jump at the address specified by (R) + (A). This exchange package FWA address is verified against the OS Bounds Register and if the jump is into a prohibited region, the exchange will not occur. EXN - (Format = fd Op Code = 00260X Size = 16 bit) | + | + | | |---|-------------|--------------| | | , | on largument | | + | | + | | 1 | <b>IEXN</b> | ld | b) Performs a conditional exchange jump at the address specified by (R) + (A). The exchange package FWA is verified against the OS Bounds Register and if the jump is in a prohibited region the exchange will not occur. Otherwise, if the monitor flag is clear, the exchange jump is performed and the monitor flag is set. If the flag is set, no exchange jump occurs and the instruction becomes a PASS instruction. MXN - (Format = fd Op Code = 00261X Size = 16 bit) | + | + | | |--------|------|----------| | llabel | . , | argument | | • | IMXN | - | CYBER 180 II Assembler ERS instruction. 8.0 CYBER 180 ASSEMBLER SYMBOLIC IOU INSTRUCTIONS 8.5.9.1 EXN. MXN. MAN - EXCHANGE JUMP Instructions c) Performs a conditional exchange jump at the address specified by the CPU Monitor Address (MA) register. If the monitor flag is clear, the exchange jump is performed and the flag is set. If the flag is set, the exchange jump is not performed and the instruction becomes a PASS MAN - (Format = fd Op Code = 00262X Size = 16 bit) | + | + | | |--------|------------|--------------| | llabel | loperation | largument | | + | + | <del> </del> | | 1 | IMAN | l d | - 8.5.9.2 PSN PASS Instruction - a) The PASS instructions performs no operation. PSN - (Format = fd Op Code = 002400 Size = 16 bit) | + | | | |---|------------|-----------| | | loperation | largument | | 1 | IPSN | 100 | Note, if the long/short form of an instruction is used and there's no corresponding instruction defined, the instruction acts as a PASS instruction. An example is LDN, opcode = 0014. If 1014, which would be the long form of the instruction and undefined, is used, the 1014 opcode acts as a PASS instruction. - 8.5.9.3 KPI KEYPOINI Instruction - a) Executes as a PASS instruction but allows sensing of its execution by external monitoring equipment through a test point. KPT - (Format = fd Op Code = 0027d Size = 16 bit) | + | | + | |---|------------|---| | • | loperation | • | | + | + | + | | 1 | IKPT | 1 | CYBER 180 II Assembler ERS Rev: F 8.0 CYBER 180 ASSEMBLER SYMBOLIC IOU INSTRUCTIONS 8.5.9.4 INPN - INTERRUPT PROCESSOR O C O / TUBE TUTEROUST DOGGEOGG ## 8.5.9.4 INPN = INTERRUPT PROCESSOR a) Transmits an interrupt signal for the CPU on memory port d. This interrupt signal causes the External Interrupt bit to be set in the CPU Monitor Condition Register. A serialization function is performed before this instruction is executed. That is, execution is delayed until all memory accesses on the part of the interrupted processor are complete. INPN - (Format = fd Op Code = 1026d Size = 16 bit) | + | + | + | |-------|--------------|-----------| | label | | largument | | + | <del>,</del> | T | | 1 | INPN | 14 | CYBER 180 II Assembler ERS CIDER 100 II ASSEMbler Ex. APPENDIX A APPENDIX\_A CALLING THE ASSEMBLER The Assembler is called on NOS/VE with the command name "ASSEMBLE" followed by parameters in the System Command Language format. All Assembler call parameters are optional. Parameters of the Assembler are: I INPUT=file INPUT specifies the file containing source statements that are to be assembled. If this parameter is omitted the value \$INPUT will be used. B BINARY\_OBJECT=file BINARY\_OBJECT specifies the file to receive the object text (binary) that is generated by the assembler. If this parameter is omitted the value LGO will be used. L LIST=file LIST specifies the file to receive the assembly listing. If this parameter is omitted the value \$LIST will be used. E ERROR=file ERROR specifies the file to receive the listing of assembly errors. If this parameter is omitted the value \$ERRORS will be used. LO LIST\_OPTIONS=list of A, R, S, NONE LIST\_OPTIONS specifies the content of the listing file. If S is included in the list, the source and generated code are listed. If A is included, the symbol attributes listing is included. If R is specified, the cross-reference is listed. If NONE is specified, only errors will be listed. The default value is S. C CHECKS=boolean CHECKS specifies whether assembly checks are to be performed or omitted. Assembly checks are used with the CYBER 180 II Assembler ERS Rev: F APPENDIX A CALLING THE ASSEMBLER vncc100 100 nooliucu CPU instruction set to validate that the correct register type designators (A-reg or X-reg) are used. If this parameter is omitted a value of TRUE will be used. STATUS=status variable STATUS specifies a status variable to receive the command's termination status. ## **EXAMPLE:** ASSEMBLE I=SOURCE B=BIN L=LISTING LO=(S.A.R) C=TRUE CYBER 180 II Assembler ERS APPENDIX B - NOTES AND EXAMPLES ## APPENDIX B - NOIES AND EXAMPLES #### PROGRAMMING\_NOIES To fully understand the Cyber 180 Hardware instructions and thier parameters, one must first understand that the Cyber 180 machine is designed to be Stack oriented. Software written for the Cyber 180 will be written in a Stack oriented higher level language (CYBIL). However there will be some code that will have to be written in Assembly language (ie Hardware diagnostics). The following sections contain notes that will hopefully aid in writing Assembly language programs. #### REGISTER USAGE When writing in Assembly language, it is important to understand how the hardware works, especially register usage. The contents of the following registers are assumed to be as described by the hardware, and should not be overwritten. AO - Dynamic Space Pointer. Al - Current Stack Frame Pointer. A2 - Previous Save Area. A3 - Binding Section Pointer. A4 - Argument Pointer. ## GENERAL NOTES In addition to understanding the hardware, it is also important to understand some things about the Assembler. SECTIONS-SEGMENTS The relationship between the Assembler concept of Sections and the Hardware concept of Segments is similar, but differs in that two or more sections may be loaded in the same Hardware Segment when they have the same access permissions. RELOCATABILITY OF CODE Even though code in sections is assembled as absolute, the sections can be loaded as relocatable, and are accessed via pointers. MONOLITH PROGRAMS When mixing code and data in the same section, it is important to use the ALIGN command when resuming to generate code. This will ensure that the code is generated on the proper boundary. CYBER 180 II Assembler ERS NORU TOO II WOOGHOICI FUO APPENDIX B - NOTES AND EXAMPLES SAMPLE PROGRAM SAMPLE PRUGRAM ## SAMPLE\_PROGRAM ident test The following is a sample program available in the SES catalog. It is intended to aid in the understanding of the CYBER 180 CPU Assembler and the CYBER 180 hardware. sample program .defines the entry point def entl This program will pick up an entry from the Literal section, and makes a copy of it in the working section. The program is structured to use the default sections established by: the Assembler, and is executed using the C180 defaults. space use working .The working section will get loaded ia segment with read+write permissions. dum .Put here to show effect of align. bss 1 align 0.8 .Ensures word boundary. \*20(16) bytes(4 words) of temp storage bssz 20(16) temp space 3 working .The WORKING section will be loaded use into a segment with read permission. .Word boundary. align 0.8 vfd,8\*8 c'EXAMPLE ' .Test data to be moved msg space 3 use binding .The Binding section is used by the hardware to store pointers which facilitate the binding of segments. This section will be loaded into a segment with read+bind permissions. ·Creates a pointer to MSG. msg\_pt address p.msq address p, temp Creates a pointer to TEMP. temp\_pt Pointers are set up with segment numbr set to FFF, LINKER fills in this fiel. The location field will show an offsef word boundary + 2, because the 6 byteA is right justified in the 8 byte fiel. 3 space •The Code section will be loaded into use code a segment with read+execute permissio. space 1 .This proc will count the number of proc bytes moved. count pname num\_move+lc:(f:(2,0)) .Add the number of bytes set num\_move end of procedure pend space 2 ## CYBER 180 II Assembler ERS Rev: F APPENDIX B - NOTES AND EXAMPLES SAMPLE PROGRAM entl align 0,8 .Entry point on a word boundary num\_move set 0 .Initialize byte counter ente x0,33(16) .Include X0-X3 and A0-A3 when saving the environment. callrel move\_msg,a3,a4 .move a copy of msg to temp return .End execution. . Move\_msg will move data to working storage align 0,8 Ensure word boundary. move\_msq a5,a3,msg\_pt 1 a .Load into A5 the pointer to MSG. .Load data into X1. 1x x1.a5.0 a5,a3,temp\_pt .A5 = pointer to storage area. la x1,a5,0 .Store MSG. SX .Update NUM\_MOVE. count msq .Return to caller return end entl .Entl is transfer label SAMPLE EXECUTION The sample program in the previous section was executed as shown below: To be supplied later. CYBER 180 II Assembler ERS APPENDIX C - RESERVED WORDS ## APPENDIX\_C = RESERVED\_WORDS The following words or categories have special meaning and can not be redefined in the user's program. Register identifiers (AO-AF, XO-XF) Section identifiers (binding, code, stack, working) Section types (Code, Binding, Working, Common, Extwork, Extcom) Attribute identifiers (Bind, Execute, Read, Write) Machine identifiers (C180CPU, C180IOU) All pseudo and machine mnemonics. All symbols starting with the pound-sign character. Any symbol containing a colon. Special internal symbols(PADA, PADB, SECT, ASECT, DSECT) CYBER 180 II Assembler ERS Rev: F APPENDIX D - ERROR MESSAGES #### APPENDIX\_D\_=\_ERROR\_MESSAGES Error messages may appear either on the listing, and/or on the dayfile, depending on when the error is detected. #### LISIING\_ERRORS ### Message ## ALIAS NAME INVALID OR DUPLICATE #### SIGNIEICANCE The alias name has been defined as both an internal and external entry point. (ie. appearing on both a DEF or DEFG instruction and a REF instruction). #### ACTION An internal entry point must be unique. However, two external entry points can be aliased to the same linkage symbol. #### ALIASED SYMBOL MUST BE REF OR DEF SYMBOL #### SIGNIFICANCE The label field of an alias statement has not been defined in a DEF, DEFG, or REF pseudo instruction. ## ACIION Define the entry point to be aliased in a DEF, DEFG, or REF instruction. Note for a DEF or DEFG symbol, these values must be further defined as a relocatable symbol (symbol category = 6). ## ANAME SYMBOL REQUIRED FOR ATTRIBUTES REFERENCING ## SIGNIFICANCE Encountered an ATRIB statement where the user defined attribute name was not previously defined in an ANAME statement. #### ACIION Define attribute name using the ANAME pseudo instruction. #### A-REG DESIGNATOR REQUIRED ## CYBER 180 II Assembler ERS Rev: F APPENDIX D - ERROR MESSAGES LISTING ERRORS ### SIGNIEICANCE An A register is required in instruction. ## ACIION Check register specifications for instruction in ERS. ## ARGUMENT SUBFIELD MUST BE SYMBOLIC NAME ### SIGNIEICANCE The argument field of the following pseudo instructions must be a symbol and cannot be an expression: ADDRESS, ALIAS, END, ERROR, FLAG, LOCAL, OPEN, REF, SECTION, SKIPTO, and TITLE. (An exception is the address type R on the ADDRESS instruction.) #### ACIION Check the ERS for definition of the argument field. Many, of these instructions have pre-defined values for use in the argument field. #### BDP DESCRIPTOR ERROR ## SIGNIFICANCE There's an error in either the source or destination data descriptor within a BDP instruction. #### ACTION Check register specifications and descriptor limitations for instruction in ERS. #### BINDING ATTRIBUTE MUST BE BINDABLE OR NONBINDABLE ## SIGNIFICANCE The 'bind' type in the argument field of the MACHINE pseudo instruction is not one of the pre-defined values BINDABLE or NONBINDABLE. ## ACIION Check value in argument field of the MACHINE pseudo instruction. ### CHARACTER STRING TOO LONG ### SIGNIEICANCE A character string cannot exceed one line, therefore is limited to 87 characters. #### ACIION Check for missing quote mark or shorten current string. CYBER 180 II Assembler ERS Rev: F APPENDIX D - ERROR MESSAGES LISTING ERRORS #### CMD STATEMENT ILLEGAL IN PROCEDURE DEFINITION #### SIGNIEICANCE A CMD instruction is equivalent to a one statement procedure definition. Nested procedures are not allowed, therefore a CMD statement cannot be within a procedure definition. #### ACIION Take the CMD statement out of the procedure. Or redefine the CMD statement as a separate procedure and replace the CMD with a 'procedure call'. #### DATA GENERATION IN STACK OR BINDING SECTION #### SIGNIEICANCE Data cannot be initialized in the STACK or BINDING sections at assembly time. (An exception is the binding section in which pointers can be initialized with the ADDRESS pseudo instruction.) #### ACIION Check the last USE statement which was encountered. #### DISPLACEMENT VALUE IS OUT-OF-RANGE ## SIGNIEICANCE The displacement value on a machine instruction overflows the length of the field designated by the instruction. ## ACIION Check the ERS for the calculation of the address displacement to make sure the value can be represented by the number of bits allotted for the displacement (ie. for a 16 bit Q-field with sign extension the value must be in the range: -7fff(16) < value < 7fff(16)). #### DIVISION BY ZERO ATTEMPTED #### SIGNIEICANCE While evaluating an expression, an attempt to divide by zero was made. #### ACIION Check values in the divisor portion. ## ERROR STATEMENT = 'character string' CYBER 180 II Assembler ERS Rev: F APPENDIX D: - ERROR MESSAGES LISTING ERRORS CIDIINO CUMONO ## SIGNIEICANCE The expression in the ERROR statement evaluated to true causing the string or symbol in the argument field to be printed in the object listing. Control is transferred conditionally on the presence of a label in the operation subfield. #### ACIION Check ERS for rules concerning the ERROR statement and the transfer of control. #### EXPRESSION EVALUATION ERROR ## SIGNIEICANCE While processing an expression, an arithmetic overflow or underflow has occurred. The following conditions will cause this error: - exceeding the following limits in integer arithmetic - 32 bit integer $-2(31) \le M \le 2(31) 1$ - 64 bit integer $-2(63) \le M \le 2(63) 1$ - exponent overflow and underflow are detected for all single precision, but only for the leftmost part of double precision. - floating point absolute value 5.2 \* 10\*\*1232 - for general BDP instructions with data descriptors, the source operand fields will be checked for overflow but the destination operand will not. - in BDP floating point instructions, if the capacity of designated fields are exceeded such that significant digits are lost. - an exception is the CALDF and EDIT instructions, no overflow conditions detected for these. #### ACILON Check values used in the expression evaluation. ### FIELD REFERENCE ERROR ## SIGNIEICANCE This error occured because some field in the source statement requires a symbolic name but an illegal field reference (ie. F: function) or list reference (ie. symbol(X)) was encountered. The value that either of these functions represent is not a symbolic name. ## ACIION Check the fields in the source statement that require symbolic names (ie. label fields, operation subfields as in the SKIPTO statement, etc.). One of the values CYBER 180 II Assembler ERS Rev: F APPENDIX D - ERROR MESSAGES LISTING ERRORS being referenced is not defined to be a symbolic name. ### FIRST STATEMENT IS NOT IDENT #### SIGNIFICANCE The first source statement encountered by the assembler was not an IDENT instruction. The only permissible source lines before the IDENT are comments. This is also true for multiple assembly modules, the only allowable source lines between the END and the IDENT are comments. #### ACTION Delete those statements before the IDENT instruction. #### FLAG STATEMENT ERROR #### SIGNIEICANCE The FLAG statement was processed which conditionally sets an error flag. The two permissible error types are pre-defined as FATAL and WARNING. #### ACTION Processing of this statement does not affect other code. #### GENERATED CODE IS NOT "BINDABLE" #### SIGNIFICANCE The relocation information generated with a CMD, VFD, INT, or DINT statement does not correspond to the pre-defined values of the RCT or ADT fields of the Relocation attribute. Both the Relocation Container Type and the Address Displacement Type are pre-defined and the relocation information must agree with these attribute values. ### ACIION Check values on these data generating statements so as to make sure that all relocation information has the correct values. ie. one of those that is pre-defined. ## ILLEGAL ATTRIBUTE REFERENCE ### SIGNIEICANCE When evaluating the argument of an attribute, either defined in an ANAME statement or an internal attribute (ie. #REGTYP), an illegal argument was encountered or ## CYBER 180 II Assembler ERS CYBER 180 11 Assembler ERS APPENDIX D - ERROR MESSAGES LISTING ERRORS the argument was missing. This can also occur if a register specification in a symbolic machine instruction is incorrect. #### ACTION Check argument field of an attribute reference or check the ERS for correct register specifications for machine instructions. #### ILLEGAL CONTINUATION #### SIGNIEICANCE The card following a continuation card contained a non-blank character in column 1. This could also be a non-graphic character. #### ACIION Change the card following the continuation character to contain a blank in column 1. ### ILLEGAL EXPRESSION ## SIGNIEICANCE While evaluating an expression an illegal reference has been encountered by the assembler. This can be an element number reference, an attribute reference, an intrinsic or user-defined function reference. #### ACTION Check the following conditions: - element number reference - using parenthesis rather than brackets or trying to access a list value of a symbol that is not a SET/EQU symbol, - attribute reference - using parenthesis rather than brackets or having more than one argument, - intrinsic or user-defined function reference - using brackets rather than parenthesis or having no argument or a null argument field. #### ILLEGAL OR NON-GRAPHIC CHARACTER DETECTED #### SIGNIEICANCE An illegal or non-graphic character has been detected. Note that a single quote, which is not preceded by a symbolic character, will cause this error. ## ACILON The assembler accepts any graphic ASCII character in a comment or character string. Check the ERS under character set for the ASCII subset which the assembler CYBER 180 II Assembler ERS Rev: F APPENDIX D - ERROR MESSAGES LISTING ERRORS CIDIIND ENGOLD accepts as input. #### ILLEGAL STATEMENT IN FUNCTION EXPANSION ### SIGNIFICANCE A function may not generate code or change location counters, if it is called form a statement which itself, generates code. This condition may occur in any of the following statements: ALIGN, BSS, BSSZ, INT, DINT, FLOAT, DFLOAT, PDEC, VFD or a CMD call statement. ACTION Change the function or the source statement from which it is called. ## INSUFFICIENT NUMBER OF ARGUMENTS #### SIGNIFICANCE In either a CMD or VFD statement, the number of elements in the value list is less than the number of elements in the length list. ## ACTION Check the elements in the value list. Note that if the number of elements in the value list exceeds the number of elements in the length list no diagnostic occurs and any extra arguments are ignored. #### INTEGER OR REAL NUMBER CONVERSION ERROR #### SIGNIEICANCE The floating point number in the argument field of a FLOAT or DFLOAT pseudo instruction is an infinite or indefinite value. #### ACIION Limits on minimum and maximum values and exponents can be found in the CYBER 180 math library documents. #### INVALID ELEMENT NUMBER IDENTIFIER #### SIGNIEICANCE The element number being referenced has a value less than 0. ## ACIION Check expression within the brackets which must be greater than or equal to 0. CYBER 180 II Assembler ERS Rev: F APPENDIX D - ERROR MESSAGES LISTING ERRORS INVALID LOCATION COUNTER DESIGNATOR ## SIGNIEICANCE The value X in \$(X) did not evaluate to 0 or 1. ## ACIION The value X can be an expression but this expression must evaluate to 0 for current byte offset or 1 for current bit offset. If no value is given the function defaults to 0. #### INVALID MACHINE TYPE #### SIGNIEICANCE The IDENT pseudo instruction is the first statement recognized by the assembler and it pre-defines the processor type due to the argument field. If this value does not correspond with the type on the MACHINE pseudo instruction this error will be produced. Otherwise, the type in the argument field is not one of the following pre-defined values, C180CPU or C180IDU. #### ACIION Check the argument field of the IDENT and MACHINE pseudo instructions to insure they correspond to the same processor type. ## INVALID SECTION ATTRIBUTES ## SIGNIFICANCE The attributes defined on a SECTION statement are either not in the set of pre-defined attributes or there's an illegal expression in the definition of these segment access attributes. #### ACTION The pre-defined segment access attributes are: READ, WRITE, EXECUTE and BIND and the only operator permitted is the plus (+) operator. #### INVALID SECTION TYPE #### **SIGNIEICANCE** The section type used in the SECTION statement was not in the set of pre-defined types. Or the section type was CODE, BINDING or STACK and these are already defined by the assembler and cannot be redefined by the user. #### ACTION CYBER 180 II Assembler ERS CIDER TOU IT ASSEMBLET ERS APPENDIX D - ERROR MESSAGES LISTING ERRORS The section types available to the user are: WORKING, COMMON, EXTWORK and EXTCOM. #### INVALID SYMBOL ERROR ### SIGNIEICANCE The symbol encountered was illegal because of one of the following conditions: - the first character of the symbol does not begin with one of the legal alphabetic characters defined for the assembler. - there's a colon (:) somewhere in the symbol, - the symbol is in the list of the assembler's reserved words ( see Appendix C of the ERS ). #### ACIION Check symbol for illegal character or that it appears on the reserved word list. ## INVALID "TYPI" SUBFIELD IN ADDRESS STATEMENT #### SIGNIEICANCE The address type in the argument field of the ADDRESS instruction is not one of the pre-defined types. #### ACTION The address types for the ADDRESS instruction are defined as: P, C, CI, CE, or R. #### LABEL NOT SYMBOLIC NAME ## SIGNIFICANCE The label field of one of the following statements does not contain a legal symbol: ALIAS, ANAME, ATRIB, CMD, DD, WHILE, DEND, IDENT, SET or EQU. ## ACIION Check the label field on the source statement. #### MACHINE STATEMENT MUST PRECEDE CODE GENERATION #### SIGNIFICANCE The MACHINE pseudo instruction did not precede a data generating statement. ## ACTION The MACHINE pseudo instruction must appear before any statment which generates code. Also there can be only one MACHINE pseudo instruction between an IDENT and an CYBER 180 II Assembler ERS APPENDIX D - ERROR MESSAGES LISTING ERRORS END assembly unit. #### MAXIMUM SEGMENT OFFSET EXCEEDED #### SIGNIEICANCE Code has been generated in a section that overflows the maximum offset allowed by the operation system. This value is OFFFFFFF(16). ## ACTION Check the section that currently is being used for code generation. #### MISSING CONT STATEMENT #### SIGNIFICANCE While processing a procedure call or a DD/WHILE sequence of statements a SKIPTO was encountered with a name in it's argument field that did not appear before a PEND or DEND statement. This also occurs if the label on the ERROR statement does not appear. #### ACIION Check symbol names in argument field of SKIPTO statement. ## MISSING DEND STATEMENT ## SIGNIEICANCE There's no matching DEND statement for a DO directive. An END or a PEND statement was encountered first. #### ACTION Include the DEND statement in assembly module. #### MISSING OPERATION FIELD ## SIGNIEICANCE There's a value in the label field of the source statement which has nothing following it. #### ACTION A null operation field is illegal. Check source statement for missing value. ## MISSING PEND STATEMENT #### SIGNIEICANCE CYBER 180 II Assembler ERS APPENDIX D - ERROR MESSAGES LISTING ERRORS CIDIINO ENGUAD A PROC directive was encountered but no statement between this and the END statement contained PEND in the operation field. ## ACIION Include the PEND statement in the assembly module. #### NESTED PROCEDURE DEFINITION #### SIGNIEICANCE Encountered a PROC psuedo instruction between a PROC-PEND pair. #### ACTION Nested procedures are not allowed by the assembler. A PROC instruction must be followed by a PEND instruction before another PROC instruction can be processed. #### OFFSET ARGUMENT NOT ON REQUIRED BOUNDARY ## SIGNIEICANCE While processing one of the offset functions (ie. #WDFF, #HDFF, #PDFF, or #BDFF) the address of the argument does not fall on the appropriate boundary (ie. for #WDFF function the argument must be on a word boundary). #### ACIION Check the address of the function argument. Sue the ALIGN statement before the argument definition to assure the correct boundary. ## OPERAND MUST BE A REAL NUMBER #### SIGNIEICANCE An operand in the argument field of a FLOAT or DFLOAT pseudo instruction is not a legal floating point number. ## ACIION Check the operands in argument field for legal floating point numbers. Note, all floating point values must be decimal values. ## OPERAND TYPE INVALID #### SIGNIEICANCE The following pseudo instructions cause this error if the argument field is incorrect: CYBER 180 II Assembler ERS Rev: F ## APPENDIX D - ERROR MESSAGES LISTING ERRORS - ERROR argument must be a legal symbol or ascii string. - FLAG argument field must be pre-defined symbols FATAL or WARNING, - INFOMSG if there is an argument, it must be the symbol LISTON, - PDEC the argument must be an ascii string with only the characters 0 9 or '+'/'-'. The '+'/'-' must be the last character in the string. ## ACIION Check the argument field for illegal value. #### OPERATION SUBFIELD NOT A SYMBOLIC NAME ### SIGNIEICANCE One of the following two conditions has occurred: - the operation field does not have a legal symbol name in it. - or one of the following pseudo instructions does not have a legal symbol name in it's argument field: CLOSE, DEF, DEFG, LOCAL, OPEN or REF. #### ACIION Check the operation field or the argument field of the listed pseudo instructions. ## PNAME/FNAME STATEMENT MISSING ## **SIGNIEICANCE** There was no PNAME or FNAME pseudo instruction between a PROC/PEND pair. Or the PNAME/FNAME instruction was not the instruction immediately following the PROC instruction. #### ACIION The PNAME/FNAME statements must be the first instruction after the PRDC statement and there must be at least one PNAME/FNAME statement in a procedure defintion. ### PNAME/FNAME STATEMENT DUT-OF-SEQUENCE ### SIGNIEICANCE The PNAME/FNAME statement is not immediately following a PROC, FNAME, or another PNAME statement. #### ACTION The PNAME/FNAME pseudo instructions are part of the procedure's heading along with the PROC statement. No CYBER 180 II Assembler ERS CYBER 180 II Assembler ERS Rev: F APPENDIX D - ERROR MESSAGES LISTING ERRORS > other instruction can appear between a PROC and PNAME/FNAME statement. ## RELOCATABLE SYMBOL REQUIRED (CATEGORY = 6) #### SIGNIEICANCE An ADDRESS, DEF or END pseudo instruction non-relocatable symbol (ie. symbol has a category other than 6) in it's argument field. #### ACIION A relocatable term represents a location of some assembled code. These are defined in the label field of a data generating statement such as VFD, INT, DINT, FLOAT, DFLOAT, PDEC, BSS, BSSZ, ADDRESS, ORG, ALIGN or a call to a CMD instruction. The labels of the symbolic machine instructions will also have a symbol category equal to 6. ### REQUIRED OPERAND MISSING ### SIGNIEICANCE The argument field is blank on a pseudo instruction that is required to have an operand. ## ACTION The following pseudo instructions require a value to be present in the argument field: ADDRESS, ALIAS, BSS, BSSZ, CLOSE, DEF, DEFG, FLAG, LOCAL, INT, DINT, FLOAT, DFLOAT, OPEN, ORG, PDEC, POS, REF, SECTION, SKIPTO, TITLE, USE, VFD, and a call to a CMD statement. #### SECTION ALIAS NAME INVALID #### SIGNIEICANCE The 'cid' field on the SECTION statement is either not a symbol or has been previously used as a 'cid'. ## ACIION The 'cid' field is optional but if it's not used it must contain a legal null subfield (ie. two commas). If the symbol has already been used, redefine one of the fields. ## SPECIFIED SECTION SIZE EXCEEDED ## SIGNIEICANCE The amount of code generated in the section exceeded CYBER 180 II Assembler ERS Rev: F APPENDIX D - ERROR MESSAGES LISTING ERRORS the amount given by the 'maxsize' field on the SECTION statement. #### ACIION Check value for 'maxsize' field on the SECTION statement and increase this value as necessary. The maximum segment length is OFFFFFFFF(16). ### STATEMENT ILLEGAL IN IOU MODULE ## SIGNIEICANCE The ADDRESS, ALIAS, DEF, DEFG, INFOMSG, PDEC, DINT, FLOAT, DFLOAT, REF, SECTION, and USE pseudo instructions are illegal in an IOU assembly module. Delete these statements from assembly module. ## STATEMENT IS VALID ONLY WITHIN A PROCEDURE ## SIGNIEICANCE The LOCAL pseudo instruction can only be used within a procedure definition (ie. between a PROC/PEND pair). ## ACIION The LOCAL pseudo instruction is used to define symbols local to a procedure. A PEND or an END statement terminates the symbols. ## STATEMENT LABEL IS NOT UNIQUE #### SIGNIFICANCE The symbol encountered in the label field has already been defined. Note that this can be a directive or procedure/function name. #### ACIION Redefine one of the symbols and change the references to the symbol. Note if a symbol appears in the label field of a pseudo instruction that does not require a label, the symbol is not considered defined. #### STATEMENT LABEL REQUIRED ## SIGNIFICANCE The label field of the source statement is blank. ### ACIION The following pseudo instructions require a label field: ANAME, ATRIB, CMD, SET, EQU, PNAME, FNAME, and CYBER 180 II Assembler ERS Rev: F APPENDIX D - ERROR MESSAGES LISTING ERRORS SECTION. SYMBOL CANNOT BE A LOCAL OR OPENED SYMBOL ### SIGNIFICANCE The symbol in the argument field of a REF, DEF, or DEFG pseudo instruction is an OPENed, LOCAL or implied local symbol that has not been closed. ## ACIION The symbol in the argument field of either a DEF, DEFG, or REF statement must be a global symbol and cannot have appeared in a LOCAL or OPEN instruction. It also cannot be an implied local symbol. SYMBOL MUST BE DECLARED REF OR DEF #### SIGNIEICANCE The symbol in the argument field of the END pseudo instruction has not been declared as an entry point. #### ACTION If the argument field contains a transfer address, the symbol must be declared as an entry point by appearing in either a DEF, DEFG, or REF pseudo instruction in the same assembly module. ## SYNTAX ERROR #### SIGNIEICANCE The following conditions will cause this error: - an illegal character string such as missing or misplaced quote marks, - an illegal number such as a digit larger than the base allows, a base value other than binary, octal, decimal, or hexadecimal, an illegal character or a missing parenthesis, - an illegal floating point number which includes any base designator (ie. all floating point numbers are decimal). - expressions with mismatched parenthesis or illegal or missing operands. ## ACIION Check the ERS for the syntax of self-defining terms (ie. number values or character strings). Or check the expression in the source statement for illegal operands or missing operands. Note that a blank or comma terminates an expression. ## CYBER 180 II Assembler ERS Rev: F APPENDIX D - ERROR MESSAGES LISTING ERRORS ## TOO MANY ARGUMENTS #### SIGNIFICANCE The argument field of the ALIAS statement contains more than one symbol. #### ACTION The ALIAS pseudo instruction allows only one symbol in the argument field (ie. there can only be one linkage symbol aliased to an internal entry point). ### TOO MANY CHARACTERS IN SYMBOLIC NAME ### SIGNIELCANCE The symbol being processed has more than 31 characters in it. #### ACTION The maximum symbol length is 31 characters, redefine symbol to be less than 31 characters. ## TOO MANY STATEMENT LABELS ## SIGNIFICANCE The instruction encountered can have only one symbol in the label field. ## ACTION If the instruction is one of the following statements. only one symbol in the label field is allowed: ALIAS, IDENT, PNAME, FNAME or a code generating statement which has the symbol category 6 (this includes the symbolic machine instructions). #### "TRALABEL" FIELD INVALID #### SIGNIFICANCE In an IOU module, the 'tralabel' field of the END pseudo instruction is not blank. ## ACTION The 'tralabel' field of the END instruction is invalid in an IOU module and must be blank. ## TRUNCATION ERROR ## SIGNIEICANCE The value that is being put into a field specified by a CMD or VFD statement must be truncated to fit. CYBER 180 II Assembler ERS APPENDIX D - ERROR MESSAGES LISTING ERRORS ## ACTION This message is turned on by the value 1 in the argument field of the TRUNC pseudo instruction. If no TRUNC instruction has been processed in the assembly module the value defaults to zero. Check the TRUNC statement in the ERS to see what constitutes loss of significance. #### UNDEFINED OPERATION SUBFIELD #### SIGNIEICANCE The symbol in the operation field is not a pseudo instruction, symbolic machine instruction, an intrinsic or user-defined function (ie. appeared on a FNAME statement), a procedure definition (ie. appeared on a PNAME statement) or appeared on a CMD statement. ## ACIION Check the symbol in the operation field for a valid symbol that is either a pre-defined instruction or function or is a user-defined procedure or function. ## UNDEFINED SYMBOLIC NAME "symbolic\_name" #### SIGNIEICANCE This error occurs when trying to evaluate an expression or function where one of the operands or argument is undefined. It also occurs when a REF, DEF or DEFG symbol has not appeared as a label for a code generating statement. ## ACIION Symbol defintion occurs when a symbol appears in the label field of a statement ( CPU, IOU or pseudo instruction) unless the label field is ignored or used for some other purpose. #### VALUE OUT-DE-RANGE ## SIGNIEICANCE The following conditions will cause this error: - ANAME argument field < 0 - BSS/BSSZ argument field < 0 - CMD/VFD value in the length field < 0 - SET/EQU symbol element number < 0 - LIST argument field is incorrect value (check ERS for legal value - INT/DINT argument field must be in the following range: ## CYBER 180 II Assembler ERS Rev: F APPENDIX D - ERROR MESSAGES LISTING ERRORS CPU - -7FFFFFFF(16) < M < 7FFFFFFF(16) - IOU -7FFF(16) < M < 7FFF(16) - ORG CPU argument field < 0 or > OFFFFFFFF(16) IOU argument field < load\_address (from IDENT statement) or > OFFF(16) - DO/WHILE argument field < 0 - SECTION the offset, alignment, or maxsize values are < 0 or > OFFFFFFFF(16) - SKIPTO F:(1,1) < 0 - PAGE argument field < 0 - TRUNC argument field does not equal 0 or 1. ## ACIION Check ERS for each pseudo instruction for the legal values. #### X-REGISTER DESIGNATOR #### SIGNIEICANCE An X-register is required in the instruction. ACTION Check register specifications for instruction in ERS. APPENDIX E ----- ## APPENDIX\_E # CYBER 180 CPU SYMBOLIC MACHINE INSTRUCTION SUMMARY | REF # | INSTRUCTION | OPERANOS | IOPCODE | |-------|-------------|-----------------|----------| | 001 | LBYTS, s | Xk,Aj,Xi,D | 100->07 | | 009 | LBYT,XO | Xk,Aj,Xi,D | 1 A4 | | 013 | l LBYTP, j | Xk,Q≉ | 86 | | 005 | 1 LXI | Xk,Aj,Xi,Tabel≈ | 1 A2 | | 006 | 1 LX | Xk,Aj,label≎ | 82 | | 014 | LBIT | l Xk,Aj,Q,XO | 88 | | 020 | LMULT | Xk,Aj,Q | 80 | | 016 | LAI | l Ak,Aj,Xi,D | I AO | | 017 | ! LA | l Ak,Aj,Q | 84 | | 000 | CONTC | VI 41 VI D | 100 > 05 | | 003 | | Xk,Aj,Xi,D | 108->DF | | | SBYT,XO | Xk,Aj,Xi,D | A5 | | | SXI | Xk,Aj,Xi,label* | 1 A3 | | | I SX | Xk,Aj,label* | 83 | | | SBIT | Xk,Aj,Q,XO | 89 | | | SMULT | Xk,Aj,Q | 81 | | | SAI | Ak,Aj,Xi,D | 1 A1 | | 019 | I SA | Ak,Aj,Q | 85 | | 022 | ADDX | Xk,Xj | 24 | | | ADDR | Xk,Xj | 20 | | | ADDXQ | l Xk,Xj,Q | 88 | | | ADDRQ | Xk,Xj,Q | 1 8A | | | INCX | l Xk,j | 10 | | 029 | INCR | l Xk, j | 28 | | | | | 1 | | 023 | SUBX | i Xk,Xj | 25 | | 030 | SUBR | Xk,Xj | 21 | | 167 | DECX | l Xk,j | 1 11 | | 031 | 1 DECR | Xk,j | 29 | | | 1 | | 1 | | | MULX | Xk,Xj | 26 | | | MULR | Xk,Xj | 22 | | | MULXQ | Xk,Xj,Q | B2 | | 033 | MULRQ | l Xk,Xj,Q | 1 8C | ## CYBER 180 II Assembler ERS APPENDIX E CYBER 180 CPU SYMBOLIC MACHINE INSTRUCTION SUMMARY | REF # | INSTRUCTION | OPERANDS | I OP CODE | |-------|-------------|--------------|------------| | 025 | DIVX | Xk,Xj | 27 | | 034 | DIVR | Xk,Xj | 23 | | 035 | CMPX | X1,Xj,Xk | 2D | | 036 | CMPR | X1,Xj,Xk | 2C | | 049 | CPYXX | Xk•Xj | <br> 0D | | | CPYRR | Xk,Xj | OC | | 050 | CPYAX | Xk•Aj | I OB | | 051 | CPYAA | l Ak,Aj | 09 | | 052 | CPYXA | Ak,Xj | 1A | | 054 | ADDAQ | l Ak,Aj,Q | 8E | | 055 | ADDPXQ | Ak,Xj,label≄ | 8F | | 056 | ADDAX | l Ak,Xj | 2A | | 161 | ADDAD | Ak,Ai,D,j | A7 | | 057 | ENTP | ≀<br> Xk•j | 30 | | 058 | ENTN | l Xk,j | 3E | | 059 | ENTE | Xk,Q | <b>8</b> D | | 060 | ENTL | XO,jk | 1 3F | | 061 | ENTZ | l Xk | 1 IF | | | ENTO | | 1 | | | ENTS | | 1 | | 164 | ENTX | l X1,jk | 39 | | 165 | ENTC | l X1,jkQ | 87 | | 169 | ENTA | XO, jkQ | B3 | | 065 | IORX | Xk,Xj | 18 | | 066 | XORX | l Xk,Xj | 19 | | 067 | | Xk,Xj | 1A | | | NOTX | Xk,Xj | 18 | | | INHX | Xk,Xj | 1 1C | | | ISOM | Xk,Xi,D,j** | I AC | | 071 | | Xk,Xj,Xi,D | AD | | 072 | | Xk,Xj,Xi,D | AE | | 145 | MARK | Xk,X1,j | 1E<br> | | 097 | CNIF | Xk,Xj | 3A | | 098 | CNFI | Xk,Xj | 38 | | 099 | ADDF | Xk•Xj | 30 | | 100 | SUBF | l Xk•Xj | 31 | | 103 | MULF | l Xk,Xj | 32 | | 104 | DIVF | Xk,Xj | 33 | ## CYBER 180 II Assembler ERS CIDEN TOO IT WOSEMBIEL FUS APPENDIX E CYBER 180 CPU SYMBOLIC MACHINE INSTRUCTION SUMMARY | REF # | INSTRUCTION | OPERANDS | IOPCODE | |-------|-------------|-----------------|---------| | 114 | CMPF | X1,Xj,Xk | 1 3C | | | ADDD | Xk,Xj | 1 34 | | | SUBD | Xk,Xj | 35 | | | MULD | Xk•Xj | 1 36 | | | DIVD | Xk,Xj | 37 | | | | | | | 062 | SHFC | Xk,Xj,Xi,D | A8 | | | SHFX | Xk,Xj,Xi,D | 1 A9 | | 064 | | Xk,Xj,Xi,D | I AA | | | | | 1 | | 037 | BRXEQ | Xj,Xk,Tabel* | 94 | | | BRXNE | Xj,Xk,label≎ | 95 | | | BRXGT | Xj,Xk,label≄ | 96 | | 040 | BRXGE | Xj,Xk,Tabel≄ | 1 97 | | 041 | BRREQ | Xj,Xk,label* | 90 | | 042 | BRRNE | Xj,Xk,label≄ | 91 | | 043 | BRRGT | Xj,Xk,1abel≄ | 92 | | 044 | BRRGE | Xj,Xk,label≎ | 1 93 | | 1 | | | 1 | | 109 | BRFEQ | Xj,Xk,label≎ | 98 | | 110 | BRFNE | Xj,Xk,label* | 1 99 | | 111 | BRFGT | Xj,Xk,label≄ | 1 9A | | 112 | BRFGE | Xj,Xk,label≉ | 1 9B | | 113 | BROVR | Xk,label≎ | 1 9E | | | BRUND | | | | | BRINF | | 1 | | | | | 1 | | _ | BRINC | Xj,Xk,label≎ | 9C | | | BRSEG | X1,Aj,Ak,label∻ | 90 | | _ | BRREL | l Xk | 1 2E | | | BRDIR | Aj,Xk | ! 2F | | 134 | BRCR | j,k,label* | ! 9F | | | | | | | | CALLSEG | label*,Aj,Ak | 85 | | | CALLREL | l label*,Aj,Ak | B0 | | 117 | • • • • • • | jk** | 04 | | | POP | jk** | 06 | | 120 | | jk** | 02 | | 121 | HALT | jk** | 00 | | 122 | INTRUPT | Xk,j*≎ | 03 | | 124 | Lincer | l vi. At vo | 1 | | 124 | LBSET | Xk,Aj,XO | 1 14 | | 125 | CMPXA | Xk,Aj,XO,label∻ | 84 | | 126 | TPAGE | Xk,Aj | 1 16 | | 127 | LPAGE | l Xk,Xj,X1 | 1 17 | CYBER 180 II Assembler ERS APPENDIX E CYBER 180 CPU SYMBOLIC MACHINE INSTRUCTION SUMMARY | REF #1 | INSTRUCTION | OPERANDS | | OPCODE | |-------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------------------|--------------|------------| | 130 | CPYSX | Xk,Xj | | I OE | | 131 | CPYXS | Xk,Xj | | 1 OF | | 132 | CPYTX | Xk,Xj | | 08 | | 136 | KEYPOINT | j,Xk,Q | | 81 | | 138 | PURGE | Xj,k | | 05 | | 139 | EXECUTE, s | j,k,i,D | | CO->C7 | | 074 | ADDN,AJ,XO | Ak,X1 | SD DD | 70 | | 156 | ADDI,Xi,D | Ak,XI,j | 00 | FB | | 096 | CALDF,Aj,XO | Xk,Ai,D | SD | F4 | | 084 | CMPB,Aj,XO | Ak,X1 | SD DD | 77 | | 085 | CMPC,Aj,XO | Ak,X1,Ai,D | SD DD | E9 | | 083 | CMPN,Aj,XO | Ak,XI | SD DD | 74 | | 155 | CMPI,Xi,D | Ak,X1,j | סס | FA | | 077 | DIVN,Aj,XO | Ak,X1 | SD DD | 73 | | 091 | EDIT,Aj,XO | Ak,X1,Ai,D | SD DD | ED | | 089 | MOVB,Aj,XO | Ak,X1 | SD DD | 76 | | 154 | MOVI,XÎ,D | Ak,X1,j | DD | <b>F</b> 9 | | 092 | MOVN, A j, XO | Ak,X1 | SD DD | 75 | | 076 | MULN,Aj,XO | Ak,X1 | SD DD | 72 | | 078 | SCLN,Aj,XO | Ak,X1,Xi,D | SD DD | E4 | | 079 1 | SCLR,Aj,XO | Ak,X1,Xi,D | SD DD | E5 | | 086 | SCNB,Aj,XO | Ak,X1,Ai,D | 00 | f F3 | | 075 | SUBN,Aj,XO | Ak,X1 | SD DD | 71 | | 088 | TRANB, A I, XO | Ak,X1,Ai,D | SD DD | l EB | | was well as | and the second section of s | Construction of the second | <del>-</del> | • | - NOIE 1: \*-This field will be modified by the Assembler. - NOIE 1: \*\*-Parameter can optionally be left blank. - NDIE 2: SD and DD are Source Descriptor and Destination Descriptor. They both have the format $F_1T_1L_1D_2$ . APPENDIX E ## APPENDIX\_E ### II\_ASSEMBLER\_DIFFERENCES\_VERSUS\_CI\_ASSEMBLER A conversion program is provided to convert CI CPU source programs to II CPU source programs. Language differences which can be converted are indicated by a "\*" in the list. ## SUMMARY of CI -> II CPU Assembler Differences - 1. II version uses 64-bit integer precision in evaluating operands and performing arithmetic and logical operations. - Multiple source statements per line are not allowed. - 3. \* All symbol names may be 31 characters maximum length (versus 8 for the CI Assembler). - 4. MACHINE pseudo instruction type will identify CPU or IOU assembly type and corresponding object text generation. - 5. IDENT statement will have operands for IDU module. - 6. \* ADVF pseudo instruction is not valid in II Assembler. - 7. \* CYBIL data notation is used for numeric data. - 8. Certain pseudo instructions are limited to the CPU Assembler. - 9. Mnemonics that reserve storage (like BSS, INT, etc.) reserve bytes in a CPU module and words in an IOU module. - 10. EBCDIC constants not available in II Assembler. - 11. XTEXT pseudo instruction not available. - 12. # Element number of symbol referenced as s[n] in II Assembler versus s(n) in CI Assembler. - 13. \* II Assembler scans to column 88 versus 72 for CI Assembler. ### CYBER 180 II Assembler ERS DIOCK 100 IX NJJUHOTU, ENJ APPENDIX F II ASSEMBLER DIFFERENCES VERSUS CI ASSEMBLER 14. \* II Assembler requires first statement input to be IDENT and if a statement follows END then it must be IDENT. - 15. \* GEN statements are combined with VFD statements in II Assembler. - 16. Byte alignment is not performed for CMD or VFD statements in II Assembler. - 17. Only byte alignment is performed for INT, DINT, FLOAT, and DFLOAT statements in a CPU module. - 18. LITERALS are not supported by II Assembler. Also not supported are the LITORG statement and literal function (L:). - 19. \* The object code listing format statement (OJC) is not supported by the II Assembler. Listing format of the II Assembler is hexadecimal. - 20. \* Real numbers (FLOAT & DFLOAT statements) must have a decimal point in II Assembler. # CPU Instruction Directory | LBYTS - (Format = SjkiD Op Code = DO-D7 Ref# = | | |--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------| | 001) | 7-4 | | SBYTS - (Format = SjkiD Op Code = D8-DF Ref# = | | | 003) | 7-4 | | LXI - (Format = jkiD Op Code = A2 Ref# = 005) | 7-5 | | LX - (Format = jkQ Op Code = 82 Ref# = 006) | 7-5 | | SXI - (Format = jkiD Op Code = A3 Ref# = 007) | 7-5 | | SX - (Format = jkQ Op Code = 83 Ref# = 008) | 7-6 | | LBYT - (Format = jkiD Op Code = A4 Ref# = 009) | 7-6 | | SBYT - (Format = jkiD Op Code = A5 Ref# = 011) | 7-6 | | LBYTP - (Format = jkQ Op Code = 86 Ref# = 013) | 7-7 | | LBIT - (Format = jkQ Op Code = 88 Ref# = 014) | 7-7 | | SBIT - (Format = jkQ Op Code = 89 Ref# = 015) | 7-7 | | LAI - (Format = jkiD Op Code = AO Ref# = 016) | 7-7 | | LA - (Format = jkQ Op Code = 84 Ref# = 017) | 7-8 | | SAI - (Format = jkiD Op Code = Al Ref# = 018) | 7-8 | | SA - (Format = jkQ Op Code = 85 Ref# = 019) | 7-8 | | LMULT - (Format = jkQ Op Code = 80 Ref# = 020) | 7-9 | | SMULT - (Format = jkQ Dp Code = 81 Ref# = 021) | 7-9 | | The state of s | 7-9 | | ADDX - (Format = jk Dp Code = 24 Ref# = 022) | -10 | | | <b>'-10</b> | | | 7-10 | | | <b>'-10</b> | | | 7-11 | | | <b>'-11</b> | | | ·-11 | | | '-11 | | | 7-12 | | | 7-12 | | | | | | 7-12<br>7-12 | | | <b>7-12</b> | | | 7-13<br>7-13 | | | '-13 | | , | 7-13 | | | 7-13 | | | 7-14 | | | -14 | | | 7-14 | | <b>→</b> ' | 1-15 | | · · · · · · · · · · · · · · · · · · · | <b>1-15</b> | | | 7-16 | | | -16 | | | 7-16 | | | <b>1-17</b> | | | 1-17 | | | 7-17 | | | <b>'-18</b> | | | 7-18 | | | 7-18 | | BRDIR - (Format = $jk$ Op Code = $2F$ Ref# = $048$ ) 7 | 7-19 | ``` MOVI - (Format = jkiD1 Op Code = F9 Ref# = 154) . . 7-49 CMPI - (Format = jkiD1 Op Code = FA Ref# = 155) . . 7-50 ADDI - (Format = jkiD1 Op Code = FB Ref# = 156) . . 7-52 7-52 CNIF - (Format = jk Op Code = 3A Ref# = 097) 7-57 CNFI - (Format = ik Op Code = 38 Ref# = 098) 7-58 ADDF - (Format = jk Dp Code = 30 Ref# = 099) 7-58 SUBF - (Format = jk Op Code = 31 Ref# = 100) 7-58 MULF - (Format = jk Dp Code = 32 Ref# = 103) 7-59 DIVF - (Format = ik Op Code = 33 Ref# = 104) 7-59 ADDD - (Format = ik Dp Code = 34 Ref# = 105) 7-59 SUBD - (Format = jk Op Code = 35 Ref# = 106) 7-60 MULD - (Format = jk Dp Code = 36 Ref# = 107) 7-60 DIVD - (Format = jk Op Code = 37 Ref# = 108) . . . 7-60 7-60 BRFEQ - (Format = jkQ Op Code = 98 Ref# = 109) . . 7-61 BRFNE - (Format = ikQ Op Code = 99 Ref# = 110) 7-62 BRFGT - (Format = jkQ Op Code = 9A Ref# = 111) 7-62 BRFGE - (Format = jkQ Op Code = 98 Ref# = 112) 7-62 BROVR - (Format = jkQ Op Code = 9E Ref# = 113) 7-63 BRUND - (Format = jkQ Op Code = 9E Ref# = 113) BRINF - (Format = jkQ Op Code = 9E Ref# = 113) 7-63 7-63 CMPF - (Format = jk Op Code = 3C Ref# = 114) . . . 7-63 7-63 EXECUTE - (Format = SjkiD Op Code = CO-C7 Ref# = 7-64 HALT - (Format = jk Op Code = 00 Ref# = 121) . . . . SYNC - (Format = jk Op Code = 01 Ref# = 194) . . . 7-64 7-64 CALLSEG - (Format = jkQ Op Code = 85 Ref# = 115) . CALLREL - (Format = jkQ Op Code = 80 Ref# = 116) . 7-65 7-66 RETURN - (Format = jk Op Code = 04 Ref# = 117) . . 7-67 POP - (Format = jk Op Code = 06 Ref# = 118) . . . . 7-67 EXCHANGE - (Format = jk 0p Code = 02 Ref# = 120) . KEYPOINT - (Format = jk 0p Code = 81 Ref# = 136) . 7-68 7-69 CMPXA - (Format = jkQ Op Code = B4 Ref# = 125) . . 7-69 LBSET - (Format = jk Op Code = 14 Ref# = 124) . . . TPAGE - (Format = jk Op Code = 16 Ref# = 126) . . . CPYTX - (Format = jk Op Code = 08 Ref# = 132) . . . 7-70 7-70 7-71 7-71 LPAGE - (Format = jk \ Op \ Code = 17 \ Ref# = 127) . . . 7-72 INTRUPT - (Format = jk Op Code = 03 Ref# = 122) . . 7-73 BRCR - (Format = jkQ Op Code = 9F Ref# = 134) . . . 7-74 CPYSX - (Format = jk Op Code = OE Ref# = 130) . . . 7-75 CPYXS - (Format = jk Op Code = OF Ref# = 131) . . . PURGE - (Format = jk Op Code = 05 Ref# = 138) . . . 7-76 7-76 7-77 ADDXV - ( Format = ikiD \square p Code = 44 Ref# = 172) . 7-78 SUBXV - ( Format = jkiD Op Code = 45 Ref# = 173) 7-79 CMPEQV - ( Format = jkiD Op Code = 50 Ref# = 176) . CMPLTV - ( Format = jkiD Op Code = 51 Ref# = 177) . 7-80 7-80 CMPGEV - ( Format = ikiD Op Code = 52 Ref# = 178) . 7-80 CMPNEV - ( Format = ikiD Op Code = 53 Ref# = 179) . 7-80 SHFV - ( Format = jkiD Op Code = 40 Ref# = 180) . . 7-81 ``` 86/10/17 Rev: F ``` IDRV - ( Format = jkiD Op Code = 48 Ref# = 181) . . 7-82 XORV - ( Format = jkiD Op Code = 49 Ref# = 182) . . 7-82 ANDV - ( Format = jkiD Op Code = 4A Ref# = 183) . . 7-82 CNIFY - ( Format = jkiD Dp Code = 48 Ref# = 184) CNFIV - ( Format = jkiD Dp Code = 4C Ref# = 185) 7-83 7-83 ADDFV - ( Format = jkiD Op Code = 40 Ref# = 186) 7-83 SUBFV - ( Format = jkiD Op Code = 41 Ref# = 187) MULFV - ( Format = jkiD Op Code = 42 Ref# = 188) DIVFV - ( Format = jkiD Op Code = 43 Ref# = 189) SUMFV - ( Format = jkiD Op Code = 57 Ref# = 190) 7-84 7-84 7-84 7-84 MRGV - ( Format = jkiD \square p Code = 54 Ref# = 191) . . 7-85 GTHV - ( Format = jkiD Op Code = 55 Ref# = 192) . . SCTV - ( Format = jkiD Op Code = 56 Ref# = 193) . . 7-85 7-86 ``` # IOU Instruction Directory. | LJM - (Format = fdm Op Code = 0001dm Size = 32 | 0.5 | |---------------------------------------------------------|--------------| | bit) | 8-5 | | RJM - (Format = fdm Op Code = 0002dm Size = 32 | 2 - | | bit) | 8-5 | | UJN - (Format = fd Op Code = 0003d Size = 16 bit) . | 8-6 | | ZJN - (Format = fd Op Code = 0004d Size = 16 bit) . | 8-6 | | NJN - (Format = fd Op Code = 0005d Size = 16 bit) . | 8-6 | | PJN - (Format = fd Op Code = 0006d Size = 16 bit) . | 8-6 | | MJN - (Format = fd Op Code = 0007d Size = 16 bit) . | 8-7 | | | 8-7 | | SHN - (Format = fd Op Code = 0010d Size = 16 bit) . | 8-7 | | | 8-7 | | LDN - (Format = fd Op Code = 0014d Size = 16 bit) . | 8-8 | | LCN - (Format = fd Op Code = 0015d Size = 16 bit) . | 8-8 | | LDC - (Format = fdm Op Code = 0020dm Size = 32 | | | bit) | 8-8 | | LDD - (Format = fd Op Code = 0030d Size = 16 bit) . | 8-8 | | LDDL - (Format = fd Op Code = 1030d Size = 16 bit) | 8-9 | | STD - (Format = fd Op Code = 0034d Size = 16 bit) . | 8-9 | | STDL - (Format = fd Op Code = 1034d Size = 16 bit) | 8-9 | | LDI - (Format = fd Op Code = 0040d Size = 16 bit) . | 8-9 | | LDIL - (Format = fd Op Code = 1040d Size = 16 bit) | 8-10 | | STI - (Format = fd Op Code = 0044d Size = 16 bit) . | 8-10 | | STIL - (Format = fd Op Code = 1044d Size = 16 bit) | 8-10 | | LDM - (Format = fdm Op Code = 0050dm Size = 32 | | | bit) | 8-11 | | LDML - (Format = fdm Op Code = 1050dm Size = 32 | | | bit) | 8-11 | | STM - (Format = fdm Op Code = 0054dm Size = 32 | | | bit) | 8-11 | | STML - (Format = fdm Op Code = 1054dm Size = 32 | | | bit) | 8-11 | | | 8-11 | | ADN - (Format = fd Op Code = 0016d Size = 16 bit) . | 8-12 | | ADC - (Format = fdm Dp Code = 0021dm Size = 32 | | | bit) | 8-12 | | SBN - (Format = fd Op Code = 0017d Size = 16 bit) . | 8-12 | | ADD - (Format = fd Dp Code = 0031d Size = 16 bit) . | 8-12 | | ADDL - (Format = fd Op Code = 1031d Size = 16 bit) | 8-13 | | SBD - (Format = fd Op Code = 0032d Size = 16 bit) . | 8-13 | | SBDL - (Format = fd Op Code = 1032d Size = 16 bit) | 8-13 | | ADI - (Format = fd Op Code = 0041d Size = 16 bit) . | 8-13 | | ADIL - (Format = fd Op Code = 1041d Size = 16 bit) | 8-14 | | SBI - (Format = fd Op Code = 0042d Size = 16 bit) . | 8-14 | | SBIL - (Format = fd Op Code = 1042d Size = 16 bit) | 8-14 | | ADM - (Format = fdm Op Code = 0051dm Size = 32 | - A T | | bit) | | | | N-15 | | ADMI - (Format = fdm $\Omega_D$ Code = 1051dm Size = 22 | 8-15 | | ADML - (Format = fdm Op Code = 1051dm Size = 32 | 8-15 | | ADML - (Format = fdm Op Code = 1051dm Size = 32 | 8-15<br>8-15 | | ADML - (Format = fdm Op Code = 1051dm Size = 32 | | | SBML - (Format = fdm Op Code = 1052dm Size = 32 | | |-------------------------------------------------------|--------| | bit) | 8-16 | | | 8-16 | | LMN - (Format = fd Op Code = 0011d Size = 16 bit) . | 8-16 | | LMC - (Format = fdm Op Code = 0023dm Size = 32 | | | bit) | 8-16 | | LPN - (Format = fd Op Code = 0012d Size = 16 bit) . | 8-17 | | LPC - (Format = fdm Op Code = 0022dm Size = 32 | | | bit) | 8-17 | | SCN - (Format = fd Op Code = 0013d Size = 16 bit) . | 8-17 | | LMD - (Format = fd Op Code = 0033d Size = 16 bit) . | 8-18 | | LMDL - (Format = fd Op Code = 1033d Size = 16 bit) | 8-18 | | LPDL - (Format = fd Op Code = 1022d Size = 16 bit) | 8-18 | | LMI - (Format = fd Op Code = 0043d Size = 16 bit) . | 8-19 | | LMIL - (Format = fd Dp Code = 1043d Size = 16 bit) | 8-19 | | LPIL - (Format = fd Op Code = 1023d Size = 16 bit) | 8-19 | | LMM - (Format = fdm Op Code = 0053dm Size = 32 | | | | 8-20 | | bit) | 0-20 | | | 8-20 | | bit) | 0-20 | | LPML - (Format = fdm Op Code = 1024dm Size = 32 | 0-11 | | bit) | 8-21 | | | 8-21 | | RAD - (Format = $fd$ Op Code = 0035d Size = 16 bit). | 8-21 | | RADL - (Format = fd Op Code = 1035d Size = 16 bit) | 8-22 | | AOD - (Format = fd Op Code = 0036d Size = 16 bit). | 8-22 | | ADDL - (Format = fd Op Code = 1036d Size = 16 bit) | 8-22 | | SOD - (Format = $fd$ Op Code = 0037d Size = 16 bit) . | 8-22 | | SODL - (Format = fd Op Code = 1037d Size = 16 bit) | 8-23 | | RAI - (Format = fd Op Code = 0045d Size = 16 bit) . | 8-23 | | RAIL - (Format = fd Op Code = 1045d Size = 16 bit) | 8-23 | | ADI - (Format = fd Op Code = 0046d Size = 16 bit) . | 8-23 | | ADIL - (Format = fd Dp Code = 1046d Size = 16 bit) | 8-24 | | SDI - (Format = fd Op Code = 0047d Size = 16 bit) . | 8-24 | | SOIL - (Format = fd Op Code = 1047d Size = 16 bit) | 8-24 | | RAM - (Format = fdm Op Code = 0055dm Size = 32 | | | bit) | 8-25 | | RAML - (Format = fdm Op Code = 1055dm Size = 32 | | | bit) | 8-25 | | ADM - (Format = fdm Op Code = 0056dm Size = 32 | | | bit) | 8-25 | | ADML - (Format = fdm Op Code = 1056dm Size = 32 | | | bit) | 8-26 | | SDM - (Format = fdm Dp Code = 0057dm Size = 32 | | | bit) | 8-26 | | SDML - (Format = fdm Op Code = 1057dm Size = 32 | 0 4, 0 | | bit) | 8-26 | | | 8-26 | | LRD - (Format = fd Op Code = 0024d Size = 16 bit) | 8-28 | | SRD - (Format = fd Dp Code = 0025d Size = 16 bit) . | 8-28 | | CRD - (Format = fd Op Code = 0060d Size = 16 bit) . | 8-30 | | CRDL - (Format = 1d Op Code = 1060d Size = 16 bit) | 8-31 | | | | | CWD - (Format = fd Op Code = 0062d Size = 16 bit) . | 8-31 | #### 86/10/17 CYBER 180 II Assembler ERS Rev: F CMDL: - (Format = fd Op Code = 1062d Size = 16 bit) 8-31 CRM - (Format = fdm Dp Code = 0061dm Size = 32 8-32 CRML - (Format = fdm Op Code = 1061dm Size = 32 8-32 CWM - (Format = fdm Op Code = 0063dm Size = 32 8-32 CWML - (Format = fdm Op Code = 1063dm Size = 32 8-33 RDSL - (Format = fd Op Code = 1000d Size = 16 bit) 8-33 RDCL - (Format = fd Op Code = 1001d Size = 16 bit) 8-34 8-34 AJM - (Format = fscm Op Code = 00640cm Size = 32 8-34 SCF - (Format = fscm Op Code = 00641cm Size = 32 8-35 FSJM - (Format = fscm Op Code = 1064Xcm Size = 32 8-35 IJM - (Format = fscm Op Code = 00650cm Size = 32 8-35 FCJM - (Format = fscm Op Code = 1065Xcm Size = 32 8-35 FJM - (Format = fscm Op Code = 00660cm Size = 32 8-36 EJM - (Format = fscm Op Code = 00670cm Size = 32 8-36 SFM - (Format = fscm Op Code = 00661cm Size = 32 8-36 CFM - (Format = fscm Dp Code = 00671cm Size = 32 8-36 CCF - (Format = fscm Op Code = 00651cm Size = 32 8-37 IAN - (Format = fsc Op Code = 00700c Size = 16 8-37 IAN - (Format = fsc Op Code = 00701c Size = 16 8-37 DAN - (Format = fsc Op Code = 00720c Size = 16 8-38 DAN - (Format = fsc Op Code = 00721c Size = 16 8-38 IAM - (Format = fscm Op Code = 00710cm Size = 32 bit) 8-38 IAPM - (Format = fscm Op Code = 10710cm Size = 32 8-41 DAM - (Format = fscm Op Code = 00730cm Size = 32 8-41 DAPM - (Format = fscm Op Code = 10730cm Size = 32 8-42 ACN - (Format = fsc Op Code = 00740c Size = 16 8-42 ACN - (Format = fsc Op Code = 00741c Size = 16 8-42 DCN - (Format = fsc Op Code = 00750c Size = 16 | CYBER 180 II Assembler ERS | 86/10/17<br>Rev: F | |-----------------------------------------------------|--------------------| | bit) | 8-43 | | bit) | 8-43 | | bit) | 8-43 | | bit) | 8-44 | | bit) | 8-44 | | bit) | 8-44 | | | | | EXN - (Format = fd Op Code = 00260X Size = 16 bit) | 8-45 | | MXN - (Format = fd Op Code = 00261X Size = 16 bit) | 8-45 | | MAN - (Format = fd Op Code = 00262X Size = 16 bit) | 8-46 | | PSN - (Format = fd Op Code = 002400 Size = 16 bit) | 8-46 | | KPT - (Format = fd Op Code = 0027d Size = 16 bit) . | 8-46 | | INPN - (Format = fd Op Code = 1026d Size = 16 bit) | 8-47 | ## 86/10/17 Rev: F # Table of Contents | 2.1.1 FIELD | | | |--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------------------------------------------|------| | 1-1 APPLICABLE DOCUMENTS | 1.0 SCOPE | 1-1 | | 2-1.1 FIELD | 1.1 APPLICABLE DOCUMENTS | 1-1 | | 2-1.1 FIELD | | | | 2-1.1 STATEMENT | 2.0 LANGUAGE STRUCTURE | 2-1 | | 2.1.1 FIELD | | 2-1 | | 2-1.2 SUBFIELD | | 2-1 | | 2-1.3 NULL FIELD 2-2 COMMENTS 2-2.1 STATEMENT CONTINUATION 2-3.3 CHARACTER SET 2-4 SYMBOL DEFINITION 2-5.2 SYMBOL DEFINITION 2-5.2 SYMBOL DEFINITION 2-6.2 SYMBOL ATTRIBUTES 2-7.2 SYMBOL ATTRIBUTES 2-7.5 REGISTERS 2-7.6 DATA NOTATION 2-7.6 DATA NOTATION 2-7.6 SYMBOL DATA NOTATION 2-7.7 EXPRESSIONS 2-11 2-7.1 TERMS 2-7.2 ORDER OF EVALUATION 2-7.3 THE LOGICAL NOT OPERATOR 2-7.3 THE LOGICAL NOT OPERATOR 2-7.5 THE BINARY SHIFT OPERATOR 2-7.5 THE BINARY SHIFT OPERATOR 2-7.6 THE COMPARISON OPERATORS 2-7.6 ABSOLUTE AND RELOCATABLE TERMS AND EXPRESSIONS 2-15 3.0 PROGRAM STRUCTURE 3-1 PROGRAM SECTIONS 3-1.1 DEFAULT SECTIONS 3-1.2 THE BINDING SECTION 3-2 SECTION CONTROL 4-1.1 IDENT - MODULE IDENTIFICATION 4-1.2 END - END MODULE 4-2 BINARY CONTROL 4-2.1 HACHINE - DECLARE OBJECT PROCESSOR TYPE 4-3 SYMBOL ASSIGNMENT 4-4-3 ALIAS - EQUATE LINKAGE SYMBOLS 4-10 4-4.2 REF-DECLARE EXTERNAL 4-4.3 ALIAS - EQUATE LINKAGE SYMBOLS 4-10 | | 2-2 | | 2.2.1 STATEMENT CONTINUATION 2.3.1 STATEMENT CONTINUATION 2.3.1 CHARACTER SET 2.4.2 SYMBOL DEFINITION 2.4.1 LINKAGE SYMBOLS 2.4.2 SYMBOL ATTRIBUTES 2.5 REGISTERS 2.6.2 DATA NOTATION 2.6.1 SELF DEFINING TERMS 2.7.2 CAC.2 NUMERIC DATA NOTATION 2.7.1 TERMS 2.7.2 ORDER OF EVALUATION 2.7.2 ORDER OF EVALUATION 2.7.3 THE LOGICAL NOT OPERATOR 2.7.4 LOGICAL AND, OPERATOR 2.7.5 THE BINARY SHIFT OPERATOR 2.7.6 THE COMPARISON OPERATOR 2.8 ABSOLUTE AND RELOCATABLE TERMS AND EXPRESSIONS 2.11 2.70 PROGRAM STRUCTURE 3.1.1 DEFAULT SECTIONS 3.1.2 THE BINDING SECTION 3.1.1 DEFAULT SECTIONS 3.2.1 FORCING PARCEL ALIGNMENT 4.0 PSEUDO INSTRUCTIONS 4.1 MODULE IDENTIFICATION 4.1.1 IDENT - MODULE IDENTIFICATION 4.1.2 END - END MODULE 4.2.1 MACHINE - DECLARE OBJECT PROCESSOR TYPE 4.3 SYMBOL ASSIGNMENT 4.4.3 ALIAS - EQUATE LINKAGE SYMBOLS 4.10 DEF, DEFG-DECLARE ENTRY SYMBOLS 4.4.10 DEF, DEFG-DECLARE ENTRY SYMBOLS 4.4.10 DEF, DEFG-DECLARE ENTRY SYMBOLS 4.4.10 DEF, DEFG-DECLARE EXTERNAL SYMBOLS 4.4.10 DEF, DEFG-DECLARE EXTERNAL SYMBOLS 4.4.10 END, DEFCLARE EXTERNAL SYMBOLS 4.4.2 REF-DECLARE EXTERNAL SYMBOLS 4.4.3 ALIAS - EQUATE LINKAGE SYMBOLS 4.10 CAC.2 DEFT. 4.11 DEF, DEFG-DECLARE EXTERNAL SYMBOLS 4.12 CAC.2 DEFT. SYMBOLS 4.13 ALIAS - EQUATE LINKAGE SYMBOLS 4.10 CAC.2 DEFT. SYMBOLS 4.11 DEFT. SYMBOLS 4.12 DEFT. SYMBOLS 4.13 ALIAS - EQUATE LINKAGE SYMBOLS 4.11 CAC.2 DEFT. SYMBOLS 4.12 DEFT. SYMBOLS 4.13 ALIAS - EQUATE LINKAGE SYMBOLS 4.11 DEFT. SYMBOLS 4.12 DEFT. SYMBOLS 4.13 ALIAS - EQUATE LINKAGE SYMBOLS 4.14 CAC.2 REF-DECLARE EXTERNAL SYMBOLS 4.16 CAC.2 DEFT. SYMBOLS 4.17 DEFT. SYMBOLS 4.18 CAC.2 DATA SYMBOLS 4.19 DEFT. SYMBOLS 4.10 DEFT. SYMBOLS 4.10 DEFT. SYMBOLS 4.11 DEFT. SYMBOLS 4.11 DEFT. SYMBOLS 4.12 DEFT. SYMBOLS 4.12 DEFT. SYMBOLS 4.14 CAC.2 DATA SYMBOLS 4.14 CAC.2 DATA SYMBOLS 4.14 CAC.2 DATA SYMBOLS 4.14 CAC.2 DATA SYMBOLS 4.14 CAC.2 DATA SYMBOLS 4.17 DEFT. SYMBOLS 4.18 | | 2-2 | | 2-2.1 STATEMENT CONTINUATION 2-3 CHARACTER SET 2-4 SYMBOL DEFINITION 2-5 2-4.1 LINKAGE SYMBOLS 2-5 2-4.2 SYMBOL ATTRIBUTES 2-5.7 REGISTERS 2-7 2-6 DATA NOTATION 2-7 2-6.1 SELF DEFINING TERMS 2-7 2-6.2 NUMERIC DATA NOTATION 2-7 2-7.1 TERMS 2-7.2 ORDER OF EVALUATION 2-7.2 ORDER OF EVALUATION 2-12 2-7.3 THE LOGICAL NOT OPERATOR 2-7.4 LOGICAL AND, OR, EXCLUSIVE OR 2-7.5 THE BINARY SHIFT OPERATOR 2-7.6 THE COMPARISON OPERATORS 2-14 2-7.6 THE COMPARISON OPERATORS 2-15 3.0 PROGRAM STRUCTURE 3-1 PROGRAM SECTIONS 3-1 STIPE BINDING SECTION 3-2 SECTION CONTROL COUNTER 3-1 DEFAULT SECTIONS 3-2 SECTION CONTROL COUNTER 3-2 SECTION CONTROL COUNTER 4-1 MODULE IDENTIFICATION 4-1 HODOULE IDENTIFICATION 4-1 MODULE IDENTIFICATION 4-1 MODULE IDENTIFICATION 4-1 MODULE IDENTIFICATION 4-1 MODULE IDENTIFICATION 4-2 BINARY CONTROL 4-3 SYMBOL ASSIGNMENT 4-2 BINARY CONTROL 4-3 SYMBOL ASSIGNMENT 4-4-3 ALIAS PECLARE OBJECT PROCESSOR TYPE 4-3 SYMBOL ASSIGNMENT 4-4-3 ALIAS PECLARE EXTERNAL SYMBOLS 4-6 4-4-1 DEF, DEFG-DECLARE ENTRY SYMBOLS 4-6 4-4-1 DEF, DEFG-DECLARE ENTRY SYMBOLS 4-10 4-4-2 REF-DECLARE EXTERNAL | | 2-3 | | 2-4 SYMBOL DEFINITION | | | | 2.4.1 LINKAGE SYMBOLS 2.4.2 SYMBOL ATTRIBUTES 2.5 REGISTERS 2.6.2 SYMBOL ATTRIBUTES 2.5 REGISTERS 2.6.1 SELF DEFINING TERMS 2.6.2 NUMERIC DATA NOTATION 2.7.2 CO.2 NUMERIC DATA NOTATION 2.7.1 TERMS 2.7.2 ORDER OF EVALUATION 2.7.2 ORDER OF EVALUATION 2.7.3 THE LOGICAL NOT OPERATOR 2.7.4 LOGICAL AND, OR, EXCLUSIVE OR 2.7.5 THE BINARY SHIFT OPERATOR 2.7.6 THE COMPARISON OPERATORS 2.7.6 THE COMPARISON OPERATORS 2.8 ABSOLUTE AND RELOCATABLE TERMS AND EXPRESSIONS 2.19 3.0 PROGRAM STRUCTURE 3.1 PROGRAM SECTIONS 3.1.1 DEFAULT SECTIONS 3.1.2 THE BINDING SECTION 3.2 SECTION CONTROL COUNTER 3.3.2.1 FORCING PARCEL ALIGNMENT 4.0 PSEUDO INSTRUCTIONS 4.1 MODULE IDENTIFICATION 4.1.1 IDENT - MODULE 4.2.2 END - END MODULE 4.2.3 BINARY CONTROL 4.3 SYMBOL ASSIGNMENT 4.4.3 SYMBOL ASSIGNMENT 4.3 SYMBOL ASSIGNMENT 4.3.3 ATRIB DIRECTIVE 4.3.4 USE OF THE ANAME AND ATRIB PSEUDO INSTRUCTIONS 4.5 ANAME DIRECTIVE 4.3.4 USE OF THE ANAME AND ATRIB PSEUDO INSTRUCTIONS 4.5 ANAME DIRECTIVE 4.3.4 USE OF THE ANAME AND ATRIB PSEUDO INSTRUCTIONS 4.5 ANAME DIRECTIVE 4.3.4 USE OF THE ANAME AND ATRIB PSEUDO INSTRUCTIONS 4.4 MODULE LINKAGE 4.4.1 DEF, DEFG-DECLARE ENTRY SYMBOLS 4.4.2 REF-DECLARE EXTERNAL SYMBOLS 4.4.3 ALIAS - EQUATE LINKAGE SYMBOLS 4.4.4 REF-DECLARE EXTERNAL SYMBOLS 4.4.3 ALIAS - EQUATE LINKAGE SYMBOLS 4.4.3 ALIAS - EQUATE LINKAGE SYMBOLS 4.4.4.3 ALIAS - EQUATE LINKAGE SYMBOLS 4.4.5 ALIAS - EQUATE LINKAGE SYMBOLS 4.4.10 DEF, DEFG-DECLARE EXTERNAL SYMBOLS 4.4.2 REF-DECLARE EXTERNAL SYMBOLS 4.4.3 ALIAS - EQUATE LINKAGE SYMBOLS 4.4.10 DEF, DEFG-DECLARE EXTERNAL SYMBOLS 4.4.11 DEFT - DECLARE EXTERNAL SYMBOLS 4.4.12 REF-DECLARE EXTERNAL SYMBOLS 4.4.13 ALIAS - EQUATE LINKAGE SYMBOLS 4.4.10 DEF, DEFG-DECLARE EXTERNAL SYMBOLS 4.4.11 DEFT - DECLARE EXTERNAL SYMBOLS 4.4.11 DEFT - DECLARE EXTERNAL SYMBOLS 4.4.12 REF-DECLARE EXTERNAL SYMBOLS 4.4.13 ALIAS - EQUATE LINKAGE SYMBOLS 4.4.14 DEF, DEFG-DECLARE EXTERNAL SYMBOLS 4.4.15 DETACLORY 4.4.16 DEFT. DECLARE EXTERNAL SYMBOLS 4.4.17 DEFT. DETACLORY 4.4.18 DETACLORY 4.4.19 DEFT. DETACLORY 4.4.19 DEFT. | | | | 2.4.1 LINKAGE SYMBOLS 2.4.2 SYMBOL ATTRIBUTES 2.6.2 SYMBOL ATTRIBUTES 2.5 REGISTERS 2.6 DATA NOTATION 2.6.1 SELF DEFINING TERMS 2.6.2 NUMERIC DATA NOTATION 2.7.2 EXPRESSIONS 2.7 EXPRESSIONS 2.7.1 TERMS 2.7.2 ORDER OF EVALUATION 2.7.3 THE LOGICAL NOT OPERATOR 2.7.4 LOGICAL AND, OR, EXCLUSIVE DR 2.7.5 THE BINARY SHIFT OPERATOR 2.7.6 THE COMPARISON OPERATOR 2.7.6 THE COMPARISON OPERATORS 2.14 2.7.6 THE COMPARISON OPERATORS 2.15 ABSOLUTE AND RELOCATABLE TERMS AND EXPRESSIONS 2.15 3.0 PROGRAM STRUCTURE 3.1 PROGRAM SECTIONS 3.1.1 DEFAULT SECTIONS 3.1.2 THE BINDING SECTION 3.2 SECTION CONTROL COUNTER 3.2.1 FORCING PARCEL ALIGNMENT 4.0 PSEUDO INSTRUCTIONS 4.1 MODULE IDENTIFICATION 4.1 IDENT - MODULE IDENTIFICATION 4.1.1 IDENT - MODULE IDENTIFICATION 4.1.2 END - END MODULE 4.2.1 MACHINE - DECLARE OBJECT PROCESSOR TYPE 4.3.2 SYMBOL ASSIGNMENT 4.3.1 SET/EQU - ASSIGNMENT 4.3.2 ANAME DIRECTIVE 4.3.3 ATRIB DIRECTIVE 4.3.4 USE OF THE ANAME AND ATRIB PSEUDO INSTRUCTIONS 4.5 MODULE LINKAGE 4.4.1 DEF, DEFG-DECLARE ENTRY SYMBOLS 4.4.2 REF-DECLARE EXTERNAL SYMBOLS 4.4.2 REF-DECLARE EXTERNAL SYMBOLS 4.4.3 ALIAS - EQUATE LINKAGE SYMBOLS 4.4.4 REF-DECLARE EXTERNAL SYMBOLS 4.4.2 REF-DECLARE EXTERNAL SYMBOLS 4.4.3 ALIAS - EQUATE LINKAGE SYMBOLS 4.4.1 DEF, DEFG-DECLARE SYMBOLS 4.10 | 2.4 SYMBOL DEFINITION | 2-5 | | 2.4.2 SYMBOL ATTRIBUTES 2.5 REGISTERS 2.6 DATA NOTATION 2.6.1 SELF DEFINING TERMS 2.6.2 NUMERIC DATA NOTATION 2.6.2 NUMERIC DATA NOTATION 2.7.2 C.6.2 NUMERIC DATA NOTATION 2.7.1 TERMS 2.7.2 ORDER OF EVALUATION 2.7.2 ORDER OF EVALUATION 2.7.3 THE LOGICAL NOT OPERATOR 2.7.4 LOGICAL NOT OPERATOR 2.7.5 THE BINARY SHIFT OPERATOR 2.7.6 THE COMPARISON OPERATOR 2.7.6 THE COMPARISON OPERATOR 2.8 ABSOLUTE AND RELOCATABLE TERMS AND EXPRESSIONS 2.15 3.0 PROGRAM STRUCTURE 3.1 PROGRAM SECTIONS 3.1.1 DEFAULT SECTIONS 3.1.2 THE BINDING SECTION 3.2 SECTION CONTROL COUNTER 3.2.1 FORCING PARCEL ALIGNMENT 4.0 PSEUDO INSTRUCTIONS 4.1 MODULE IDENTIFICATION 4.1.1 IDENT - MODULE IDENTIFICATION 4.1.2 END - END MODULE 4.2.1 MACHINE - DECLARE OBJECT PROCESSOR TYPE 4.3.3 NAMBE DIRECTIVE 4.3.4 USE OF THE ANAME AND ATRIB PSEUDO INSTRUCTIONS 4.4 MODULE LINKAGE 4.4.1 DEF, DEFG-DECLARE ENTRY SYMBOLS 4.4.2 REF-DECLARE EXTERNAL SYMBOLS 4.4.3 ALIAS - EQUATE LINKAGE SYMBOLS 4.1.4.3 ALIAS - EQUATE LINKAGE SYMBOLS 4.1.4.3 ALIAS - EQUATE LINKAGE SYMBOLS | | | | 2.5 REGISTERS | | | | 2-6 DATA NOTATION | | | | 2.6.1 SELF DEFINING TERMS 2.6.2 NUMERIC DATA NOTATION 2.7 EXPRESSIONS 2.7.1 TERMS 2.7.1 TERMS 2.7.2 ORDER OF EVALUATION 2.7.3 THE LOGICAL NOT OPERATOR 2.7.4 LOGICAL AND, OR, EXCLUSIVE OR 2.7.5 THE BINARY SHIFT OPERATOR 2.7.6 THE COMPARISON OPERATOR 2.7.6 THE COMPARISON OPERATORS 2.8 ABSOLUTE AND RELOCATABLE TERMS AND EXPRESSIONS 2.15 3.0 PROGRAM STRUCTURE 3.1 PROGRAM SECTIONS 3.1.1 DEFAULT SECTIONS 3.1.2 THE BINDING SECTION 3.1.2 THE BINDING SECTION 3.2 SECTION CONTROL COUNTER 3.2.1 FORCING PARCEL ALIGNMENT 4.0 PSEUDO INSTRUCTIONS 4.1 MODULE IDENTIFICATION 4.1.1 IDENT - MODULE IDENTIFICATION 4.1.2 END - END MODULE 4.2 BINARY CONTROL 4.2.1 MACHINE - DECLARE OBJECT PROCESSOR TYPE 4.3.3 SYMBOL ASSIGNMENT 4.4.3 SET/EQU - ASSIGNMENT OF VALUES 4.3.4 USE OF THE ANAME AND ATRIB PSEUDO INSTRUCTIONS 4.4 MODULE LINKAGE 4.4.1 DEF, DEFG-DECLARE ENTRY SYMBOLS 4.4.2 REF-DECLARE EXTERNAL SYMBOLS 4.4.3 ALIAS - EQUATE LINKAGE SYMBOLS 4.11 | | | | 2-6-2 NUMERIC DATA NOTATION 2-7 2.7 EXPRESSIONS 2-11 2.7-1 TERMS 2-7-1 TERMS 2-7-2 ORDER OF EVALUATION 2-12 2.7-3 THE LOGICAL NOT OPERATOR 2-7-3 THE LOGICAL NOT OPERATOR 2-7-5 THE BINARY SHIFT OPERATOR 2-7-6 THE COMPARISON OPERATORS 2-14 2.7-6 THE COMPARISON OPERATORS 2-14 2.7-6 THE COMPARISON OPERATORS 2-15 3.0 PROGRAM STRUCTURE 3-1 PROGRAM SECTIONS 3-1 THE BINDING SECTIONS 3-1 DEFAULT SECTIONS 3-1.1 DEFAULT SECTIONS 3-2 SECTION CONTROL COUNTER 3-2 SECTION CONTROL COUNTER 4-1 HODULE IDENTIFICATION 4-1 MODULE IDENTIFICATION 4-1 MODULE IDENTIFICATION 4-1 MODULE IDENTIFICATION 4-2 BINARY CONTROL 4-2 BINARY CONTROL 4-2 BINARY CONTROL 4-3 SYMBOL ASSIGNMENT 4-4 4-3 SYMBOL ASSIGNMENT 4-4 4-3 ANAME DIRECTIVE 4-3 4-3 ANAME DIRECTIVE 4-3 4-4-1 DEF, DEFG-DECLARE BNJECT PROCESSOR TYPE 4-5 4-3-4 MODULE LINKAGE 4-6 4-4-1 DEF, DEFG-DECLARE ENTRY SYMBOLS 4-10 4-4-2 REF-DECLARE EXTERNAL SYMBOLS 4-10 4-4-3 ALIAS - EQUATE LINKAGE SYMBOLS | 2.6.1 SELE DEFINING TERMS | | | 2-7 EXPRESSIONS | 2.6.2 NUMERIC DATA NOTATION | | | 2.7.1 TERMS 2.7.2 ORDER OF EVALUATION 2.7.3 THE LOGICAL NOT OPERATOR 2.7.4 LOGICAL AND, OR, EXCLUSIVE OR 2.7.5 THE BINARY SHIFT OPERATOR 2.7.6 THE COMPARISON OPERATOR 2.7.6 THE COMPARISON OPERATORS 2.8 ABSOLUTE AND RELOCATABLE TERMS AND EXPRESSIONS 2.15 3.0 PROGRAM STRUCTURE 3.1 PROGRAM SECTIONS 3.1.1 DEFAULT SECTIONS 3.1.2 THE BINDING SECTION 3.1.2 SECTION CONTROL COUNTER 3.2.1 FORCING PARCEL ALIGNMENT 4.0 PSEUDO INSTRUCTIONS 4.1 MODULE IDENTIFICATION 4.1.1 IDENT - MODULE IDENTIFICATION 4.1.2 END - END MODULE 4.2 BINARY CONTROL 4.2.1 MACHINE - DECLARE OBJECT PROCESSOR TYPE 4.3 SYMBOL ASSIGNMENT 4.3.1 SET/EQU - ASSIGNMENT OF VALUES 4.3.2 ANAME DIRECTIVE 4.3.3 ATRIB DIRECTIVE 4.3.4 USE OF THE ANAME AND ATRIB PSEUDO INSTRUCTIONS 4.4 MODULE LINKAGE 4.4.1 DEF, DEFG-DECLARE ENTRY SYMBOLS 4.4.2 REF-DECLARE EXTERNAL SYMBOLS 4.4.3 ALIAS - EQUATE LINKAGE SYMBOLS 4.11 | 2.7 EXPRESSIONS | | | 2.7.2 ORDER OF EVALUATION | | | | 2.7.3 THE LOGICAL NOT OPERATOR 2.7.4 LOGICAL AND, OR, EXCLUSIVE OR 2.7.5 THE BINARY SHIFT OPERATOR 2.7.6 THE COMPARISON OPERATORS 3.1.1 THE COMPARISON OPERATORS 3.1.1 THE COMPARISON OPERATORS 3.1.1 THE COMPARISON OPERATORS 3.1.1 THE COMPARISON OPERATORS 3.2.1 FORCION 3 | | | | 2.7.4 LOGICAL AND, OR, EXCLUSIVE OR 2.7.5 THE BINARY SHIFT OPERATOR 2.7.6 THE COMPARISON OPERATORS 2.8 ABSOLUTE AND RELOCATABLE TERMS AND EXPRESSIONS 2.15 3.0 PROGRAM STRUCTURE 3.1 PROGRAM SECTIONS 3.1.1 DEFAULT SECTIONS 3.1.2 THE BINDING SECTION 3.2 SECTION CONTROL COUNTER 3.2.1 FORCING PARCEL ALIGNMENT 4.0 PSEUDO INSTRUCTIONS 4.1 MODULE IDENTIFICATION 4.1 I IDENT - MODULE IDENTIFICATION 4.1.2 END - END MODULE 4.2 BINARY CONTROL 4.2.1 MACHINE - DECLARE OBJECT PROCESSOR TYPE 4.3 SYMBOL ASSIGNMENT 4.3.1 SET/EQU - ASSIGNMENT OF VALUES 4.3.2 ANAME DIRECTIVE 4.3.3 ATRIB DIRECTIVE 4.3.4 USE OF THE ANAME AND ATRIB PSEUDO INSTRUCTIONS 4.4 MODULE LINKAGE 4.4.1 DEF, DEFG-DECLARE ENTRY SYMBOLS 4.4.2 REF-DECLARE EXTERNAL SYMBOLS 4.4.3 ALIAS - EQUATE LINKAGE SYMBOLS 4.11 | 2 7 2 THE LOCICAL MOT DECATOR | | | 2.7.5 THE BINARY SHIFT OPERATOR 2.7.6 THE COMPARISON OPERATORS 2.8 ABSOLUTE AND RELOCATABLE TERMS AND EXPRESSIONS 2-15 3.0 PROGRAM STRUCTURE 3.1 PROGRAM SECTIONS 3.1.1 DEFAULT SECTIONS 3.1.2 THE BINDING SECTION 3.2 SECTION CONTROL COUNTER 3.2.1 FORCING PARCEL ALIGNMENT 4.0 PSEUDO INSTRUCTIONS 4.1 MODULE IDENTIFICATION 4.1.1 IDENT - MODULE IDENTIFICATION 4.1.2 END - END MODULE 4.2 BINARY CONTROL 4.2.1 MACHINE - DECLARE OBJECT PROCESSOR TYPE 4.3 SYMBOL ASSIGNMENT 4.3.1 SET/EQU - ASSIGNMENT OF VALUES 4.3.2 ANAME DIRECTIVE 4.3.3 ATRIB DIRECTIVE 4.3.4 USE OF THE ANAME AND ATRIB PSEUDO INSTRUCTIONS 4.4 MODULE LINKAGE 4.4.1 DEF, DEFG-DECLARE ENTRY SYMBOLS 4.4.2 REF-DECLARE EXTERNAL SYMBOLS 4.4.3 ALIAS - EQUATE LINKAGE SYMBOLS 4.11 | 2 7 A LOCICAL AND DD EYCHICIVE DD | | | 2.7.6 THE COMPARISON OPERATORS 2.8 ABSOLUTE AND RELOCATABLE TERMS AND EXPRESSIONS 2-15 3.0 PROGRAM STRUCTURE 3.1 PROGRAM SECTIONS 3.1.1 DEFAULT SECTIONS 3.1.2 THE BINDING SECTION 3.2 SECTION CONTROL COUNTER 3.2.1 FORCING PARCEL ALIGNMENT 4.0 PSEUDO INSTRUCTIONS 4.1 MODULE IDENTIFICATION 4.1.1 IDENT - MODULE IDENTIFICATION 4.1.2 END - END MODULE 4.2 BINARY CONTROL 4.3 SYMBOL ASSIGNMENT 4.3.1 SET/EQU - ASSIGNMENT OF VALUES 4.3.2 ANAME DIRECTIVE 4.3.3 ATRIB DIRECTIVE 4.3.4 USE OF THE ANAME AND ATRIB PSEUDO INSTRUCTIONS 4.4 MODULE LINKAGE 4.4.1 DEF, DEFG-DECLARE ENTRY SYMBOLS 4.4.2 REF-DECLARE EXTERNAL SYMBOLS 4.4.3 ALIAS - EQUATE LINKAGE SYMBOLS 4.11 | | | | 2.8 ABSOLUTE AND RELOCATABLE TERMS AND EXPRESSIONS . 2-15 3.0 PROGRAM STRUCTURE | | | | 3.0 PROGRAM STRUCTURE 3.1 PROGRAM SECTIONS 3.1.1 DEFAULT SECTIONS 3.1.2 THE BINDING SECTION 3.2 SECTION CONTROL COUNTER 3.2.1 FORCING PARCEL ALIGNMENT 4.0 PSEUDO INSTRUCTIONS 4.1 MODULE IDENTIFICATION 4.1.1 IDENT - MODULE IDENTIFICATION 4.1.2 END - END MODULE 4.2 BINARY CONTROL 4.2.1 MACHINE - DECLARE OBJECT PROCESSOR TYPE 4.3.1 SET/EQU - ASSIGNMENT 4.3.1 SET/EQU - ASSIGNMENT OF VALUES 4.3.2 ANAME DIRECTIVE 4.3.3 ATRIB DIRECTIVE 4.3.4 USE OF THE ANAME AND ATRIB PSEUDO INSTRUCTIONS 4.4 MODULE LINKAGE 4.4.1 DEF, DEFG-DECLARE ENTRY SYMBOLS 4.4.2 REF-DECLARE EXTERNAL SYMBOLS 4.4.3 ALIAS - EQUATE LINKAGE SYMBOLS 4.11 | | | | 3.1 PROGRAM SECTIONS 3.1.1 DEFAULT SECTIONS 3.1.2 THE BINDING SECTION 3.2 SECTION CONTROL COUNTER 3.2.1 FORCING PARCEL ALIGNMENT 4.0 PSEUDO INSTRUCTIONS 4.1 MODULE IDENTIFICATION 4.1.1 IDENT - MODULE IDENTIFICATION 4.1.2 END - END MODULE 4.2 BINARY CONTROL 4.2.1 MACHINE - DECLARE OBJECT PROCESSOR TYPE 4.3 SYMBOL ASSIGNMENT 4.3.1 SET/EQU - ASSIGNMENT OF VALUES 4.3.2 ANAME DIRECTIVE 4.3.3 ATRIB DIRECTIVE 4.3.4 USE OF THE ANAME AND ATRIB PSEUDO INSTRUCTIONS 4.4 MODULE LINKAGE 4.4.1 DEF, DEFG-DECLARE ENTRY SYMBOLS 4.4.2 REF-DECLARE EXTERNAL SYMBOLS 4.4.3 ALIAS - EQUATE LINKAGE SYMBOLS 4.11 | 2.8 ABSULUTE AND RELUCATABLE TERMS AND EXPRESSIONS | 2-15 | | 3.1 PROGRAM SECTIONS 3.1.1 DEFAULT SECTIONS 3.1.2 THE BINDING SECTION 3.2 SECTION CONTROL COUNTER 3.2.1 FORCING PARCEL ALIGNMENT 4.0 PSEUDO INSTRUCTIONS 4.1 MODULE IDENTIFICATION 4.1.1 IDENT - MODULE IDENTIFICATION 4.1.2 END - END MODULE 4.2 BINARY CONTROL 4.2.1 MACHINE - DECLARE OBJECT PROCESSOR TYPE 4.3 SYMBOL ASSIGNMENT 4.3.1 SET/EQU - ASSIGNMENT OF VALUES 4.3.2 ANAME DIRECTIVE 4.3.3 ATRIB DIRECTIVE 4.3.4 USE OF THE ANAME AND ATRIB PSEUDO INSTRUCTIONS 4.4 MODULE LINKAGE 4.4.1 DEF, DEFG-DECLARE ENTRY SYMBOLS 4.4.2 REF-DECLARE EXTERNAL SYMBOLS 4.4.3 ALIAS - EQUATE LINKAGE SYMBOLS 4.11 | 2 A DEDCOAM CIDICIUS | 2.1 | | 3.1.1 DEFAULT SECTIONS 3.1.2 THE BINDING SECTION 3.2 SECTION CONTROL COUNTER 3.2.1 FORCING PARCEL ALIGNMENT 4.0 PSEUDO INSTRUCTIONS 4.1 MODULE IDENTIFICATION 4.1.1 IDENT - MODULE IDENTIFICATION 4.1.2 END - END MODULE 4.2 BINARY CONTROL 4.2.1 MACHINE - DECLARE OBJECT PROCESSOR TYPE 4.3 SYMBOL ASSIGNMENT 4.3.1 SET/EQU - ASSIGNMENT OF VALUES 4.3.2 ANAME DIRECTIVE 4.3.3 ATRIB DIRECTIVE 4.3.4 USE OF THE ANAME AND ATRIB PSEUDO INSTRUCTIONS 4.4 MODULE LINKAGE 4.4.1 DEF, DEFG-DECLARE ENTRY SYMBOLS 4.4.2 REF-DECLARE EXTERNAL SYMBOLS 4.4.3 ALIAS - EQUATE LINKAGE SYMBOLS 4.11 | 3.0 PROGRAM STRUCTURE | | | 3.1.2 THE BINDING SECTION 3.2 SECTION CONTROL COUNTER 3.2.1 FORCING PARCEL ALIGNMENT 4.0 PSEUDO INSTRUCTIONS 4.1 MODULE IDENTIFICATION 4.1.1 IDENT - MODULE IDENTIFICATION 4.1.2 END - END MODULE 4.2 BINARY CONTROL 4.2.1 MACHINE - DECLARE OBJECT PROCESSOR TYPE 4.3 SYMBOL ASSIGNMENT 4.3.1 SET/EQU - ASSIGNMENT OF VALUES 4.3.2 ANAME DIRECTIVE 4.3.3 ATRIB DIRECTIVE 4.3.4 USE OF THE ANAME AND ATRIB PSEUDO INSTRUCTIONS 4.4 MODULE LINKAGE 4.4.1 DEF, DEFG-DECLARE ENTRY SYMBOLS 4.4.2 REF-DECLARE EXTERNAL SYMBOLS 4.4.3 ALIAS - EQUATE LINKAGE SYMBOLS 4.10 | 3.1 PRUGRAM SECTIONS | | | 3.2 SECTION CONTROL COUNTER 3.2.1 FORCING PARCEL ALIGNMENT 4.0 PSEUDO INSTRUCTIONS 4.1 MODULE IDENTIFICATION 4.1.1 IDENT - MODULE IDENTIFICATION 4.1.2 END - END MODULE 4.2 BINARY CONTROL 4.2.1 MACHINE - DECLARE OBJECT PROCESSOR TYPE 4.3 SYMBOL ASSIGNMENT 4.3.1 SET/EQU - ASSIGNMENT OF VALUES 4.3.2 ANAME DIRECTIVE 4.3.3 ATRIB DIRECTIVE 4.3.4 USE OF THE ANAME AND ATRIB PSEUDO INSTRUCTIONS 4.4 MODULE LINKAGE 4.4.1 DEF, DEFG-DECLARE ENTRY SYMBOLS 4.4.2 REF-DECLARE EXTERNAL SYMBOLS 4.4.3 ALIAS - EQUATE LINKAGE SYMBOLS 4.11 | 3.1.1 DEFAULT SECTION | | | 3.2.1 FORCING PARCEL ALIGNMENT | 3.1.2 THE BINDING SECTION | | | 4.0 PSEUDO INSTRUCTIONS | | | | 4.1 MODULE IDENTIFICATION | 3.2.1 FURCING PARCEL ALIGNMENT | 3-4 | | 4.1 MODULE IDENTIFICATION | | | | 4.1.1 IDENT - MODULE IDENTIFICATION | | | | 4.1.2 END - END MODULE 4.2 BINARY CONTROL 4.2.1 MACHINE - DECLARE OBJECT PROCESSOR TYPE 4.3 SYMBOL ASSIGNMENT 4.3.1 SET/EQU - ASSIGNMENT OF VALUES 4.3.2 ANAME DIRECTIVE 4.3.3 ATRIB DIRECTIVE 4.3.4 USE OF THE ANAME AND ATRIB PSEUDO INSTRUCTIONS 4.4 MODULE LINKAGE 4.4.1 DEF, DEFG-DECLARE ENTRY SYMBOLS 4.4.2 REF-DECLARE EXTERNAL SYMBOLS 4.4.3 ALIAS - EQUATE LINKAGE SYMBOLS 4-10 | | | | 4.2 BINARY CONTROL 4.2.1 MACHINE - DECLARE OBJECT PROCESSOR TYPE 4.3 SYMBOL ASSIGNMENT 4.3.1 SET/EQU - ASSIGNMENT OF VALUES 4.3.2 ANAME DIRECTIVE 4.3.3 ATRIB DIRECTIVE 4.3.4 USE OF THE ANAME AND ATRIB PSEUDO INSTRUCTIONS 4.4 MODULE LINKAGE 4.4.1 DEF, DEFG-DECLARE ENTRY SYMBOLS 4.4.2 REF-DECLARE EXTERNAL SYMBOLS 4.4.3 ALIAS - EQUATE LINKAGE SYMBOLS 4-10 | | | | 4.2.1 MACHINE - DECLARE OBJECT PROCESSOR TYPE | 4.1.2 END - END MODULE | 4-2 | | 4.3 SYMBOL ASSIGNMENT | 4.2 BINARY CONTROL | | | 4.3.1 SET/EQU - ASSIGNMENT OF VALUES | | | | 4.3.2 ANAME DIRECTIVE | 4.3 SYMBOL ASSIGNMENT | 4-4 | | 4.3.3 ATRIB DIRECTIVE | 4.3.1 SET/EQU - ASSIGNMENT OF VALUES | 4-5 | | 4.3.3 ATRIB DIRECTIVE | 4.3.2 ANAME DIRECTIVE | 4-8 | | 4.3.4 USE OF THE ANAME AND ATRIB PSEUDO INSTRUCTIONS 4.4 MODULE LINKAGE | 4.3.3 ATRIB DIRECTIVE | 4-8 | | 4.4 MODULE LINKAGE | | 4-9 | | 4.4.1 DEF, DEFG-DECLARE ENTRY SYMBOLS | | | | 4.4.2 REF-DECLARE EXTERNAL SYMBOLS | | | | 4.4.3 ALIAS - EQUATE LINKAGE SYMBOLS 4-11 | | | | | | | | | | 4-11 | | | OOLIAN | |-------------------------------------------------------|--------| | CYBER 180 II Assembler ERS | Rev: | | 4.5 DATA GENERATION | 4-13 | | 4.5.1 BSSZ-RESERVE ZEROED STORAGE | | | 4.5.2 INT - GENERATE INTEGERS | | | 4.5.3 DINT - GENERATE 64-BIT INTEGERS | | | 4.5.4 FLOAT - GENERATE SINGLE PRECISION | 7 1 7 | | FLOATING-POINT NUMBERS | 4-15 | | 4.5.5 DFLOAT - GENERATE DOUBLE PRECISION | , | | | 4-16 | | 4.5.6 PDEC - GENERATE PACKED DECIMAL DATA | 4-16 | | 4.5.7 CMD - GENERATE BIT STRING | 4-17 | | 4.5.8 VFD - VARIABLE FIELD DEFINITION | 4-18 | | 4.5.9 TRUNC - TRUNCATE | 4-19 | | 4.5.10 INFOMSG | 4-20 | | 4.6 ASSEMBLY CONTROL | 4-20 | | 4.6.1 DD/ELSE/DEND PSEUDO INSTRUCTIONS | | | 4.6.2 WHILE/ELSE/DEND PSEUDO INSTRUCTIONS | 4-23 | | 4.6.3 SKIPTO - SKIP CODE | 4-24 | | 4.7 ERROR CONTROL | 4-26 | | 4.7.1 ERROR PSEUDO OPERATION | 4-27 | | 4.7.2 FLAG - CONDITIONALLY SET ERROR FLAG | 4-28 | | 4.8 LISTING CONTROL | 4-28 | | 4.8.1 LIST - SELECT LIST OPTIONS | 4-28 | | 4.8.2 PAGE - EJECT PAGE | 4-30 | | | 4-30 | | | 4-31 | | 4.8.5 XRSY - CONCORDANCE SELECTION | 4-31 | | 4.9 SECTIONS | 4-32 | | 4.9.1 SECTION - ESTABLISH BLOCK | 4-32 | | 4.9.2 USE - USE BLOCK | 4-34 | | 4.9.3 ORG - SET SECTION COUNTER | 4-35 | | 4.9.4 POS - SET BIT POSITION IN THE SECTION COUNTER . | 4-35 | | | 4-36 | | 4.9.6 ALIGN - FORCE SECTION COUNTER ALIGNMENT | 4-37 | | 4.10 PROCEDURES | 4-37 | | 4.10.1 PARAMETER REFERENCING WITHIN PROCEDURES | 4-38 | | 4.10.1.1 Parameter Identification Examples | 4-39 | | 4.10.2 PROC - PROCEDURE HEADING | 4-39 | | 4.10.3 PNAME - PROCEDURE NAME DEFINITION | 4-40 | | 4.10.4 FNAME - FUNCTION NAME DEFINITION | 4-41 | | 4.10.5 PEND - END PROCEDURE DEFINITION | 4-42 | | 4.10.6 LOCAL - ESTABLISH LOCAL SYMBOLS | 4-42 | | 4.10.7 OPEN - DECLARE TEMPORARY SYMBOLS | 4-43 | | 4.10.8 CLOSE - ERASE TEMPORARY SYMBOLS | 4-44 | | 4.10.9 CONT - NO OPERATION | 4-44 | | 4.10.10 PROCEDURE CALLS | 4-45 | | 4.10.11 PROCEDURE EXAMPLES | 4-45 | | 4.10.11.1 Procedure Definition | 4-46 | | 4.10.11.2 LDCAL Directive's Use | 4-47 | | 5.0 ATTRIBUTE FUNCTIONS | 5-1 | | 5.1 LANGUAGE DEFINED ATTRIBUTES | 5-1 | | 5.1.1 SYMBOL CATEGORY ATTRIBUTE - SC: | 5-1 | | 5.1.2 ADDRESS MODE ATTRIBUTE | 5-3 | | CYBER 180 II Assembler ERS | 86/10/ | |-------------------------------------------------------|--------------| | | | | 5.1.3 VALUE ATTRIBUTE | 5-3<br>5-4 | | 5.1.4 LENGTH ATTRIBUTES | 5-5 | | 5.1.5 STARTING BIT POSITION ATTRIBUTE | 5-5 | | 5.1.6 ELEMENT NUMBER ATTRIBUTE | 5-6 | | 5.1.8 SYMBOL NUMBER ATTRIBUTE | 5-6 | | 5.1.9 RELOCATION ATTRIBUTE | 5-6 | | 5.2 PROGRAMMER DEFINED ATTRIBUTE FUNCTIONS | 5-7 | | 5.3 SYMBOL ATTRIBUTE EXAMPLES | 5-8 | | J. J STROOL ATTRIBUTE EXAMPLES | <i>J</i> 0 | | 6.0 OFFSET FUNCTIONS (#WOFF, #HOFF, #POFF, #BOFF) | 6-1 | | 7.0 CYBER 180 CPU SYMBOLIC MACHINE INSTRUCTIONS | 7-1 | | 7.1 SYMBOLIC NOTATION | 7-1 | | 7.2 CPU INSTRUCTION FORMATS | 7-2 | | 7.3 GENERAL CPU INSTRUCTIONS | 7-3 | | 7.3.1 LOAD AND STORE | 7-3 | | 7.3.1.1 LBYTS, SBYTS-Load/Store Bytes, Xk Length | - | | Per S | 7-4 | | 7.3.1.2 LXI, LX, SXI, SX-Load/Store Word, Xk | 7-5 | | 7.3.1.3 LBYT, SBYT-Load/Store Bytes, Xk Length Per | <b>3</b> / | | X0 | 7-6<br>7-7 | | 7.3.1.4 LBYTP-Load Bytes, Xk Length per j | 7-7 | | 7.3.1.6 LAI, LA, SAI, SA-Load/Store, Ak | 7-7 | | 7.3.1.7 LMULT, SMULT-Load/Store Multiple Registers | 7-9 | | 7.3.2 INTEGER ARITHMETIC | 7-9 | | 7.3.2.1 ADDX, ADDXQ, INCX-Integer Sum, Xk | 7-10 | | 7.3.2.2 SUBX, DECX-Integer Difference, Xk | 7-10 | | 7.3.2.3 MULX, MULXQ-Integer Product, Xk | 7-11 | | 7.3.2.4 DIVX-Integer Quotient | 7-11 | | 7.3.2.5 ADDR, ADDRQ, INCR-Integer Sum, Xk right | 7-12 | | 7.3.2.6 SUBR, DECR-Integer Difference, Xk Right | 7-12 | | 7.3.2.7 MULR, MULRQ-Integer Product, Xk Right | 7-13 | | 7.3.2.8 DIVR-Integer Quotient, Xk Right | 7-13 | | 7.3.2.9 CMPX, CMPR-Integer Compare | 7-14 | | 7.3.3 BRANCH | 7-14 | | 7.3.3.1 BRXEQ, BRXNE, BRXGT, BRXGE-Branch Conditional | 7-15 | | 7.3.3.2 BRREQ, BRRNE, BRRGT, BRRGE-Conditional, X | | | Right | 7-16 | | 7.3.3.3 BRINC-Conditional, with Increment | 7-18 | | 7.3.3.4 BRSEG-Conditional, Ak | 7-18 | | 7.3.3.5 BRREL-Unconditional Branch, (P) indexed | 7-18 | | 7.3.3.6 BRDIR-Unconditional Branch, (A) indexed | 7-19 | | 7.3.4 COPY | 7-19 | | 7.3.4.1 CPYXX-Copy to Xk from Xj | 7-19 | | 7.3.4.2 CPYAX-Copy to Xk from Aj | 7-19 | | 7.3.4.3 CPYAA-Copy to Ak from Aj | 7-20<br>7-20 | | 7.3.4.4 CPYXA-Copy to Ak from Xj | 7-20 | | 7.3.5 ADDRESS ARITHMETIC | 7-20 | | 7.3.5.1 ADDAQ-Copy A with Displacement | 7-21 | | 7 2 C 2 ADDAY COPY A WILL DISPLACEMENT | 1 L. L | | CYBER 180 II Assembler ERS | Rev: f | |---------------------------------------------------|--------------| | Displacement | 7-21 | | Displacement | 7-21 | | 7.3.5.4 ADDAD-Copy A with Displacement, Modulo | 7-22 | | 7.3.6 ENTER | 7-22 | | 7.3.6.1 ENTP, ENTN-Enter j | 7-22 | | 7.3.6.2 ENTE-Enter Q | 7-23 | | 7.3.6.3 ENTL, ENTX-Enter jk | 7-23 | | 7.3.6.4 ENTZ, ENTQ, ENTS-Enter Signs | 7-24 | | 7.3.6.5 ENTC-Enter X1 jkQ | 7-24 | | 7.3.6.6 ENTA-Enter XO jkQ | 7-25 | | 7.3.7 SHIFT | 7-25 | | 7.3.7.1 SHFC-Shift (Xj) to Xk, Circular | 7-26 | | 7.3.7.2 SHFX.SHFR-Shift (Xj) to Xk, End-Off | 7-26 | | 7.3.8 LDGICAL | 7-27 | | 7.3.8.1 IORX,XORX,ANDX-Logical Sum, Diff. and | | | Prod | 7-27 | | 7.3.8.2 NOTX-Logical Complement | 7-28 | | 7.3.8.3 INHX-Logical Inhibit | 7-28 | | 7.3.9 REGISTER BIT STRING | 7-28 | | 7.3.9.1 ISOM-Isolate Bit Mask | 7-29 | | 7.3.9.2 ISOB-Isolate into Xk | 7-29 | | 7.3.9.3 INSB-Insert into Xk | 7-30 | | 7.3.10 MARK-MARK TO BOOLEAN | 7-30 | | 7.4 BUSINESS DATA PROCESSING INSTRUCTIONS | 7-32 | | 7.4.1 GENERAL DESCRIPTION | 7-32 | | 7.4.1.1 Operation Codes | 7-34 | | 7.4.2 DATA DESCRIPTORS | 7-34 | | 7.4.2.1 BDP Descriptor, D Field | 7-35 | | 7.4.2.2 BDP Operand Type, T Field | 7-35 | | 7.4.2.3 BDP Operand Address, O Field | 7-37 | | 7.4.2.4 BDP Operand Length, F and L Fields | 7-37 | | 7.4.3 DATA AND SIGN CONVENTIONS | 7-38 | | 7.4.4 BDP NUMERIC | 7-38 | | 7.4.4.1 Arithmetic | 7-39 | | 7.4.4.2 ADDN, SUBN, MULN, DIVN-Arithmetic | 7-40 | | 7.4.4.3 SCLN, SCLR-Shift | 7-41 | | 7.4.4.4 MOVN-Move | 7-44<br>7-44 | | 7.4.4.5 CMPN-Comparison | 7-45 | | 7.4.5 BYTE | 7-45 | | 7.4.5.1 CMPB, CMPC-Comparison | 7-46 | | 7.4.5.2 SCNB-Byte Scan | 7-47 | | 7.4.5.4 MOVB-Move | 7-48 | | 7.4.5.5 EDIT-Edit | 7-48 | | 7.4.6 IMMEDIATE DATA | 7-49 | | 7.4.6.1 MOVI-Move Immed Data (XI) Right plus D to | 1-47 | | D(Ak) | 7-49 | | 7.4.6.2 CMPI-Compare Immed Data(Xi) Right plus D | 1-47 | | | 7-50 | | to D(Ak) | 7-50 | | D(Ak) | 7-52 | | 7.5 FLOATING POINT INSTRUCTIONS | 7-52 | | 7.5.1 GENERAL DESCRIPTION | 7-53 | | CYBER 180 II Assembler ERS | Rev: F | |-------------------------------------------------------|--------| | | | | 7.5.2 FORMATS | 7-53 | | 7.5.3 EXPONENT ARITHMETIC | 7-56 | | 7.5.4 NORMALIZATION | 7-56 | | 7.5.5 DOUBLE PRECISION REGISTER DESIGNATORS | 7-57 | | 7.5.6 CONVERSION | 7-57 | | 7.5.6.1 CNIF-Convert From Integer to Floating | 7-57 | | 7.5.6.2 CNFI-Convert Floating Point to Integer | 7-58 | | 7.5.7 ARITHMETIC | 7-58 | | 7.5.7.1 ADDF, SUBF-Add/Subtract, Xk | 7-58 | | 7.5.7.2 MULF-Product to XK | 7-59 | | 7.5.7.3 DIVF-Quotient to XK | 7-59 | | 7.5.7.4 ADDD, SUBD-Add/Subtract, Xk and Xk+1 | 7-59 | | 7.5.7.5 MULD-Product to Xk and Xk+1 | 7-60 | | 7.5.7.6 DIVD-Quotient to Xk and Xk+1 | 7-60 | | 7.5.8 BRANCH | 7-60 | | 7.5.8.1 BRFEQ, BRFNE, BRFGT, BRFGE-Compare and Branch | 7-61 | | 7.5.8.2 BROVR, BRUND, BRINF-Exception Branch | 7-63 | | 7.5.8.3 CMPF-Compare | 7-63 | | 7.6 SYSTEM INSTRUCTIONS | 7-64 | | 7.6.1 NON-PRIVILEGED MODE | 7-64 | | 7.6.1.1 EXECUTE, HALT, SYNC | 7-64 | | 7.6.1.2 CALLSEG, CALLREL-Call | 7-64 | | 7.6.1.3 RETURN | 7-67 | | 7.6.1.4 POP | 7-67 | | 7.6.1.5 EXCHANGE | 7-68 | | 7.6.1.6 KEYPOINT | 7-68 | | 7.6.1.7 CMPXA-Compare Swap | 7-69 | | 7.6.1.8 LBSET-Load Bit | 7-70 | | 7.6.1.9 TPAGE-Test Page | 7-70 | | 7.6.1.10 CPYTX-Copy Free Running Counter(TIME) to | | | Х | 7-71 | | X | 7-71 | | 7.6.2.1 LPAGE-Load Page Table Index | 7-72 | | 7.6.3 GLOBAL PRIVILEGED MODE | 7-72 | | 7.6.3.1 INTRUPT-Interrupt Processor | 7-73 | | 7.6.4 MIXED MODE | 7-73 | | 7.6.4.1 BRCR-Branch and Alter Condition Register . | 7-74 | | 7.6.4.2 CPYSX,CPYXS-Copy State Registers | 7-75 | | 7.6.4.3 PURGE-Purge Buffer | 7-76 | | 7.7 VECTOR INSTRUCTIONS | 7-77 | | 7.7.1 GENERAL DESCRIPTION | 7-77 | | 7.7.2 COMMON ATTRIBUTES OF VECTOR INSTRUCTIONS | 7-77 | | 7.7.3 INTEGER VECTOR ARITHMETIC | 7-78 | | 7.7.3.1 ADDXV-Add Integer Vectors | 7-78 | | 7.7.3.2 SUBXV-Subtract Integer Vectors | 7-79 | | 7.7.4 INTEGER VECTOR COMPARISON | 7-79 | | 7.7.4.1 CMPEQV-Integer Vector Comparison - Equal . | 7-79 | | 7.7.4.2 CMPLTV-Integer Vector Comparison - Less | | | Than | 7-80 | | 7.7.4.3 CMPGEV-Integer Vector Comparison - | | | Greater Than Or Equal | 7-80 | | 7.7.4.4 CMPNEV-Integer Vector Comparison - Not | | | | | | | | | | 80/10/ | |------------------------------|-----------|-------------|-----------|----------|----------|---------|--------| | CYBER 180 II As | sembler | ERS | | | | | Rev: | | | Faunt: | | | | | | 7-80 | | 7.7.5 SHIF | Equal • | CTOCHI | \D | | | | 7-81 | | 7.7.6 1.061 | CAL VECT | TORS | | | | | 7-82 | | 7.7.6 LDGI<br>7.7.6.1 | TORY-Inc | ·lusive ( | r Vecto | rs . | | | 7-82 | | 7.7.6.2 | XORV-Exc | lusive ( | r Vecto | rs . | | | 7-82 | | 7.7.6.3 | ANDV-Loc | rical And | 1 Vector | · · · | | | 7-82 | | 7.7.7 CONV | FRT VECT | nes . | | | | | 7-83 | | 7.7.7.1 | | | | | | | 7-83 | | 7.7.7.2 | | | | | ~ | | 7-83 | | 7.7.8 FLOA | | | | | | | 7-83 | | 7.7.8.1 | | | | | | | 7-83 | | 7.7.8.2 | | | | | | | 7-83 | | 7.7.8.3 | | | | | | | 7-84 | | 7.7.8.4 | | | | | | | 7-84 | | 7.7.9 FLOA | TING PO | INT VECTO | DR SUMMA | TION . | | | 7-84 | | 7.7.9.1 | | | | | | | 7-84 | | | | | | | | | 7-85 | | 7.7.9.2<br>7.7.10 GAT | HER AND | SCATTER | VECTOR | | | | 7-85 | | 7.7.10.1 | Gather | Vector | | | | • • • • | 7-85 | | 7.7.10.1<br>7.7.10.2 | Scatter | · Vector | | | | | 7-86 | | 8.0 CYBER 18 | A ACCEMI | IED CVM | 2011 C 10 | HI THETD | HETTONE | | 8-1 | | | | | | | | | 8-1 | | 8.1 SYMBOLIC<br>8.2 IOU MACH | THE THE | PHOTTON | ENDMATS | | • • • • | | 8-1 | | 8.3 IOU ADDR | THE INSI | C | FUNDALI | • • • | • • • • | • • • . | 8-3 | | 8.3.1 NO-A | DDDECC N | ADDE (NI) | | | | | 8-3 | | 8.3.2 CONS | | | | | | | 8-3 | | 8.3.3 DIPE | CT MODE | (0) | | | | | 8-3 | | 8.3.3 DIRE<br>8.3.4 INDI | SECT MUL | )F (1) | | | | | 8-3 | | 8.3.5 MEMO | RY MODE | (M) | | | | | 8-3 | | 8.4 NOMENCLA | TURE USE | ED TN TOL | INSTRU | CTIONS | | | 8-4 | | 8.5 GENERAL | | | | | | | 8-5 | | 8.5.1 BRAN | | | | | | | 8-5 | | 8.5.1.1 | 1.1M. R.D | 4. II.IN. 7 | IN. NIN | P.IN | M.IN | | 8-5 | | 8.5.2 SHIF | T INSTRI | ICTION . | | ., | | | 8-7 | | 8.5.2.1 | SHN . | | | | | | 8-7 | | 8.5.3 LOAD | AND STO | DRE INSTE | RUCTIONS | | | | 8-7 | | | | I, LDC - | | | | | | | | and CONS | STANT . | | | | | 8-8 | | 8.5.3.2 | LDD. LDD | DL. STD. | STDL - | LOAD/ST | DRE bits | by | | | | | node | | | | | 8-8 | | 8.5.3.3 | LDI. LDI | L. STI. | STIL - | LOAD/ST | DRE bits | by | | | | | mode . | | | | | 8-9 | | 8.5.3.4 | | | | | | | | | | | node | | | | | 8-10 | | 8.5.4 ARIT | HMETIC I | INSTRUCT | IONS | | | | 8-11 | | 8.5.4.1 | | | | | | | | | | | and CONS | | | | | 8-12 | | 8.5.4.2 | ADD, ADI | DL, SBD. | SBDL - | ADD/SUB | TRACT bi | ts | • | | | | T mode | | | | | 8-12 | | 8.5.4.3 | | | | | | | | | | | RECT | | | | | 8-13 | | 8.5.4.4 | | | | | | | | | | 90/10/ | |-----------------------------------------------------|----------| | YBER 180 II Assembler ERS | Rev: | | L. MEMORY 4- | 0-15 | | by MEMORY mode | 8-15 | | 8.5.5 LOGICAL INSTRUCTIONS | 8-16 | | 8.5.5.1 LMN, LMC, LPN, LPC, SCN - NO ADDRESS and | | | CONSTANT modes | 8-16 | | 8.5.5.2 LMD, LMDL, LPDL - Instructions using | | | DIRECT mode | 8-18 | | 8.5.5.3 LMI, LMIL, LPIL - Instructions using | | | INDIRECT mode | 8-19 | | 8.5.5.4 LMM, LMML, LPML - Instructions using | | | MEMDRY mode | 8-20 | | 8.5.6 REPLACE INSTRUCTIONS | 8-21 | | 8.5.6.1 RAD, RADL - REPLACE ADD using DIRECT mode . | 8-21 | | 8.5.6.2 AOD, AODL, SOD, SOOL - REPLACE | 0 21 | | ADD/SUBTRACT ONE using DIRECT | 8-22 | | | 0-22 | | 8.5.6.3 RAI, RAIL - REPLACE ADD using INDIRECT | | | mode | 8-23 | | 8.5.6.4 ADI, ADIL, SDI, SDIL - REPLACE | | | ADD/SUBTRACT using INDIRECT | 8-23 | | 8.5.6.5 RAM, RAML - REPLACE ADD using MEMORY mode . | 8-25 | | 8.5.6.6 ADM, ADML, SDM, SOML - REPLACE | | | ADD/SUBTRACT ONE using MEMORY mode | 8-25 | | 8.5.7 CENTRAL MEMORY ACCESS INSTRUCTIONS | 8-27 | | 8.5.7.1 LRD, SRD, - LOAD/STORE R Register in IOU | | | Memory | 8-28 | | 8.5.7.2 CRD, CRDL, CWD, CWDL - RD/WR CPU Memory, | The same | | DIDECT mode | 8-29 | | DIRECT mode | G Z J | | Blocks | 8-31 | | 8.5.7.4 RDSL, RDCL - READ CM and SET or CLEAR LOCK | | | | 8-33 | | 8.5.8 INPUT/OUTPUT INSTRUCTIONS | 8-34 | | 8.5.8.1 AJM, SCF, FSJM, IJM, FCJM, FJM, EJM, SFM, | | | CFM, CCF | 8-34 | | 8.5.8.2 IAN, DAN - A Register I/O Instructions | 8-37 | | 8.5.8.3 IAM, IAPM, DAM, DAPM - BLOCK I/O | | | Instructions | 8-38 | | 8.5.8.4 ACN, DCN - ACTIVATE/DEACTIVATE I/O | | | Channels | 8-42 | | 8.5.8.5 FAN, FNC - I/O Channel Functions | 8-43 | | 8.5.9 OTHER IOU INSTRUCTIONS | 8-44 | | 8.5.9.1 EXN, MXN, MAN - EXCHANGE JUMP Instructions | 8-45 | | 8.5.9.2 PSN - PASS Instruction | 8-46 | | 8.5.9.3 KPT - KEYPOINT Instruction | 8-46 | | 8.5.9.4 INPN - INTERRUPT PROCESSOR | 8-47 | | 8.5.9.4 INPN - INTERRUPT PRUCESSUR | 0-41 | | | | | APPENDIX A | A1 | | CALLING THE ASSEMBLER | A1 | | | | | APPENDIX B - NOTES AND EXAMPLES | 81 | | PROGRAMMING NOTES | 81 | | REGISTER USAGE | B1 | | GENERAL NOTES | 81 | | SAMPLE PROGRAM | 82 | | SAMPLE EXECUTION | | | CDC - ADVANCED SYSTEMS DEVELOPMENT | | |------------------------------------|--------------------| | CYBER 180 II Assembler ERS | 86/10/17<br>Rev: F | | APPENDIX C - RESERVED WORDS | <b>C1</b> | | APPENDIX D - ERROR MESSAGES | D1<br>D1 | | APPENDIX E | E1<br>E1 | | APPENDIX F | F1<br>F1 |