

Operating System/3 (OS/3)

Assembler (Series 90)

For System 80 see UP-8914

**Programmer Reference** 

This Library Memo announces the release and availability of "SPERRY UNIVAC<sup>®</sup> Operating System/3 (OS/3) Assembler Programmer Reference", UP-8227 Rev. 2.

This revision documents the following enhancements to the assembler for release 8.0:

- The display of error messages on the console
- An additional warning message when using continuation characters with macroinstructions

This revision also includes minor technical corrections to material applicable to the assembler prior to release 8.0.

<u>Destruction Notice</u>: If you are going to OS/3 release 8.0, use this revision and destroy all previous copies. If you are not going to OS/3 release 8.0, retain the copy you are now using and store this revision for future use.

Copies of UP-8227 Rev. 1, UP-8227 Rev. 1—A, UP-8227 Rev. 1—B, UP-8227 Rev. 1—C, UP-8227 Rev. 1—D and UP-8227 Rev. 1—E will be available for 6 months after the release of 8.0. Should you need additional copies of these editions, you should order them within 90 days of the release of 8.0. When ordering the previous edition of a manual, be sure to identify the exact revision and update packages desired and indicate that they are needed to support an earlier release.

Additional copies may be ordered by your local Sperry Univac representative.

| LIBRARY MEMO ONLY              | LIBRARY MEMO AND ATTACHMENTS                                | THIS SHEET IS:                     |
|--------------------------------|-------------------------------------------------------------|------------------------------------|
| Mailing Lists BZ,<br>CZ and MZ | Mailing Lists A00, A18, 75, and 76<br>(Cover and 345 pages) | Library Memo for<br>UP-8227 Rev. 2 |
|                                |                                                             | RELEASE DATE:                      |
|                                |                                                             | September, 1982                    |

# **Assembler**



Environment: 90/25, 30, 30B, 40 Systems

This document contains the latest information available at the time of preparation. Therefore, it may contain descriptions of functions not implemented at manual distribution time. To ensure that you have the latest information regarding levels of implementation and functional availability, please consult the appropriate release documentation or contact your local Sperry Univac representative.

Sperry Univac reserves the right to modify or revise the content of this document. No contractual obligation by Sperry Univac regarding level, scope, or timing of functional implementation is either expressed or implied in this document. It is further understood that in consideration of the receipt or purchase of this document, the recipient or purchaser agrees not to reproduce or copy it by any means whatsoever, nor to permit such action by others, for any purpose without prior written permission from Sperry Univac.

Sperry Univac is a division of the Sperry Corporation.

FASTRAND, SPERRY UNIVAC, UNISCOPE, UNISERVO, and UNIVAC are registered trademarks of the Sperry Corporation. ESCORT, MAPPER, PAGEWRITER, PIXIE, and UNIS are additional trademarks of the Sperry Corporation.

This document was prepared by Systems Publications using the SPERRY UNIVAC UTS 400 Text Editor. It was printed and distributed by the Customer Information Distribution Center (CIDC), 555 Henderson Rd., King of Prussia, Pa., 19406.

#### **PAGE STATUS SUMMARY**

UP-8227 Rev. 2 ISSUE: **RELEASE LEVEL:** 8.0 Forward

| Part/Section     | Page<br>Number                                                                                                                                                           | Update<br>Level | Part/Section | Page<br>Number         | Update<br>Level | Part/Section | Page<br>Number | Update<br>Level |
|------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------|--------------|------------------------|-----------------|--------------|----------------|-----------------|
| Cover/Disclaimer |                                                                                                                                                                          |                 | Appendix E   |                        |                 |              |                |                 |
| PSS              | 1                                                                                                                                                                        | _               |              | Title Page<br>1 thru 5 |                 |              |                |                 |
| Preface          | 1                                                                                                                                                                        |                 | Appendix F   |                        |                 |              |                |                 |
| Contents         | 1 thru 10                                                                                                                                                                | -               |              | Title Page<br>1 thru 6 |                 |              |                |                 |
| Section 1        |                                                                                                                                                                          |                 | Glossary     | 1 thru 17              |                 |              |                |                 |
|                  | Title Page<br>1 thru 5                                                                                                                                                   |                 | User Comment |                        |                 |              |                |                 |
| Section 2        | Title Page 1 thru 48 48a 49 thru 62 62a, 62b 63 thru 68 68a 69 thru 80 80a 81 thru 120 120a 121 thru 128 128a 129 thru 138 138a thru 138e 139 thru 146 146a 147 thru 163 |                 | Sheet        |                        |                 |              |                |                 |
| Section 3        | Title Page<br>1 thru 31                                                                                                                                                  |                 |              |                        |                 |              |                |                 |
| Section 4        | Title Page<br>1 thru 29                                                                                                                                                  |                 |              |                        |                 |              |                |                 |
| Appendix A       | Title Page<br>1 thru 24                                                                                                                                                  |                 |              |                        |                 |              |                |                 |
| Appendix B       | Title Page<br>1 thru 7                                                                                                                                                   |                 | !            |                        |                 |              |                |                 |
| Appendix C       | Title Page<br>1 thru 13                                                                                                                                                  |                 |              |                        |                 |              |                |                 |
| Appendix D       | Title Page<br>1 thru 8                                                                                                                                                   |                 |              |                        | :               |              |                |                 |

| , |   |  |  |  |
|---|---|--|--|--|
|   |   |  |  |  |
|   |   |  |  |  |
|   |   |  |  |  |
|   |   |  |  |  |
|   |   |  |  |  |
|   |   |  |  |  |
|   |   |  |  |  |
|   |   |  |  |  |
|   | · |  |  |  |
|   |   |  |  |  |

### **Preface**

This programmer reference manual is one in a series designed to be used as a quick-reference document for programmers familiar with the SPERRY UNIVAC Operating System/3 (OS/3). This particular manual describes the basic assembly language (BAL) instructions, directives, and macro definition statements that allow you to write your own assembly language programs and procedure definitions (procs).

No extensive introductory information or examples of use are provided. This type of information is presented in two other assembler manuals: an introduction to the assembler, UP-8030, and an assembler user guide, UP-8061.

The information contained in this manual is presented as follows:

#### Section 1. General Information

Provides a brief overview of the assembler, the job control stream requirements of the assembler, and the conventions that must be observed when reading and writing assembler code.

#### Section 2. BAL Application Instructions

Describes each of the BAL application instructions recognized by the OS/3 assembler. These descriptions are presented in alphabetic order by their operation code mnemonic.

#### Section 3. BAL Directives

Describes each of the directives that are used to control the operation of the assembler. These directives are also presented in alphabetic order by their operation code mnemonic.

#### Section 4. BAL Macro Definition Statements

Describes the macro definition statements used to write and call procedure definitions. These statements are presented in alphabetic order.

#### Appendixes

Contain assembler references, character set code references, math references, source corrections, and system variable symbols helpful to the BAL programmer.

#### Glossary

Defines the terms, expressions, and abbreviations peculiar to the assembler.

## **Contents**

1-1

#### **PAGE STATUS SUMMARY**

### **PREFACE**

#### **CONTENTS**

#### 1. GENERAL INFORMATION

ASSEMBLER OVERVIEW

|    | JOB CONTROL REQUIREMENTS                    | 11  |
|----|---------------------------------------------|-----|
|    | ASSEMBLER CODING FORM                       | 1-1 |
|    | Symbol Field                                | 1–2 |
|    | Operation Field                             | 1–2 |
|    | Operand Field                               | 1–2 |
|    | Comment Field                               | 1–2 |
|    | Continuation Column                         | 1-3 |
|    | Sequence Field                              | 13  |
|    | READING INSTRUCTION NOTATIONS               | 1–3 |
|    | Assembler Application Instruction Notations | 1–3 |
|    | Notation Rules and Meanings                 | 1–4 |
| 2. | BAL APPLICATION INSTRUCTIONS                |     |
|    | .A                                          | 2–1 |
|    | AD                                          | 2–2 |
|    | ADR                                         | 2–3 |
|    | AE                                          | 2–4 |
|    | AER                                         | 2–5 |
|    | АН                                          | 2–6 |
|    | AI                                          | 2–7 |

### SPERRY UNIVAC Operating System/3

UPDATE LEVEL

Contents 2 PAGE

| AL   |     | 2-8  |
|------|-----|------|
| ALR  |     | 2-10 |
| AP   |     | 2–11 |
| AR   |     | 2–13 |
| AU   |     | 2-14 |
| AUR  |     | 2–15 |
| AW   |     | 2-16 |
| AWR  |     | 2–17 |
| BAL  |     | 2–18 |
| BALR |     | 2-19 |
| BAS  |     | 2-20 |
| BASR |     | 2-20 |
| вс   |     | 2–21 |
| BCR  |     | 2–23 |
| вст  |     | 2-24 |
| BCTR |     | 2-25 |
| вхн  |     | 2–26 |
| BXLE |     | 2–27 |
| c    | * 1 | 228  |
| CD   |     | 2–29 |
| CDR  |     | 2-30 |
| CE   |     | 2–31 |
| CER  |     | 2-32 |
| СН   |     | 2–33 |
| CL   |     | 2–34 |
| CLC  |     | 2–35 |
| CLI  |     | 2–36 |

### SPERRY UNIVAC Operating System/3

UPDATE LEVEL

Contents 3 PAGE

| CLR  | 2–37          |
|------|---------------|
| СР   | 2–38          |
| CR   | 2–39          |
| CVB  | 2–40          |
| CVD  | 2–42          |
| D    | 2–43          |
| DD   | 2–44          |
| DDR  | 2–45          |
| DE   | 2–46          |
| DER  | 2–47          |
| DIAG | 2–48          |
| DP   | <b>2–48</b> a |
| DR   | 2–50          |
| ED   | 2–51          |
| EDMK | 2-56          |
| EX   | 2-58          |
| HDR  | 2–60          |
| HER  | 2–61          |
| HPR  | 262           |
| IC   | 2-62a         |
| ISK  | 2-62b         |
| L    | 2–63          |
| LA   | 2-64          |
| LCDR | 265           |
| LCER | 2-66          |
| LCR  | 2–67          |
| LCS  | 2–68          |
|      |               |

### SPERRY UNIVAC Operating System/3

UPDATE LEVEL

Contents 4
PAGE

| LD   | 2-68 |
|------|------|
| LDR  | 2–69 |
| LE   | 2-70 |
| LER  | 2–71 |
| LH   | 2–72 |
| LM   | 2–73 |
| LNDR | 2–75 |
| LNER | 2–76 |
| LNR  | 2–77 |
| LPDR | 2-78 |
| LPER | 2–79 |
| LPR  | 2-80 |
| LPSW | 2–80 |
| LR   | 2–81 |
| LTDR | 2–82 |
| LTER | 2–83 |
| LTR  | 2-84 |
| M    | 2-85 |
| MD   | 2–87 |
| MDR  | 2–88 |
| ME   | 2–89 |
| MER  | 2-90 |
| мн   | 2–91 |
| MP   | 2-92 |
| MR   | 2–94 |
| MVC  | 2–95 |
| MVI  | 2–96 |
| MVN  | 2–97 |

8227 Rev. 2
UP-NUMBER

SPERRY UNIVAC Operating System/3
UPD

Contents 5
UPDATE LEVEL PAGE

2-134

| MVO  | 2–98   |
|------|--------|
| MVZ  | 2-99   |
| N    | 2-100  |
| NC   | 2-102  |
| NI   | 2-104  |
| NR   | 2-106  |
| 0    | 2-107  |
| ос   | 2-109  |
| OI   | 2–111  |
| OR   | 2–113  |
| PACK | 2-114  |
| S    | 2–115  |
| SD   | 2-116  |
| SDR  | 2–117  |
| SE   | 2–118  |
| SER  | 2–119  |
| SH   | 2-120  |
| SIO  | 2-120a |
| SL   | 2–121  |
| SLA  | 2-123  |
| SLDA | 2–125  |
| SLDL | 2–127  |
| SLL  | 2–128  |
| SLM  | 2-128a |
| SLR  | 2–129  |
| SP   | 2-130  |
| SPM  | 2–132  |
| SR   | 2–133  |

SRA

Contents 6 8227 Rev. 2 SPERRY UNIVAC Operating System/3 UPDATE LEVEL PAGE UP-NUMBER **SRDA** 2-136 **SRDL** 2-137 SRL 2-138 2-138a **SSFS** 2-138b SSK 2-138c SSM **SSRS** 2-138d 2-138e **SSTM** 2-139 ST 2-140 STC 2-141 STD 2-142 STE 2-143 STH 2-144 STM **STR** 2-146 SU 2-146a **SUR** 2-147 2-148 **SVC** SW 2-149 2-150 **SWR** TM 2-151 2-152 TR TRT 2-154

2-156

2-157

2-158

2-159

2-161

2-162

TS

Χ

XC

ΧI

XR

UNPK

3.

### SPERRY UNIVAC Operating System/3

UPDATE LEVEL

Contents 7

| ZAP                  | 2–163 |
|----------------------|-------|
| BAL DIRECTIVES       |       |
| CCW                  | 3–1   |
| CNOP                 | 3–2   |
| СОМ                  | 3–3   |
| COPY                 | 3–5   |
| CSECT                | 3–6   |
| DC (Floating Point)  | 3–7   |
| DC (Standard Format) | 3–9   |
| DROP                 | 3–10  |
| DS                   | 3–11  |
| DSECT                | 3–12  |
| EJECT                | 3–13  |
| END                  | 3–14  |
| ENTRY                | 3–15  |
| EQU                  | 3–16  |
| EXTRN                | 3–17  |
| ICTL                 | 3–18  |
| ISEQ                 | 3–19  |
| LTORG                | 3–20  |
| OPSYM                | 3–21  |
| ORG                  | 3–23  |
| PRINT                | 3–24  |
| PUNCH                | 3–25  |
| REPRO                | 3–26  |
| SPACE                | 3–27  |
| START                | 3–28  |
| TITLE                | 3–29  |

SET

4-22

USING 3-30 **BAL MACRO DEFINITION STATEMENTS ACTR** 4-1 AGO 4-2 AIF 4-3 **ANOP** 4-4 DO 4-5 **END** 4-6 **ENDO** 4-7 **GBL** 4-8 **GBLA** 4-8 **GBLB** 4-8 **GBLC** 4-8 LCL 4-9 **LCLA** 4-9 **LCLB** 4-9 **LCLC** 4-9 **MACRO** 4-10 **Macro Call Instruction** 4-11 MEND 4-13 **MEXIT** 4-14 **MNOTE** 4-15 **Model Statement** 4-16 **NAME** 4-17 **PNOTE** 4-18 **PROC** 4-19 **Prototype Statement** 4-21

|     | SETA                                                                                                     | 425                                    |
|-----|----------------------------------------------------------------------------------------------------------|----------------------------------------|
|     | SETB                                                                                                     | 4-26                                   |
|     | SETC                                                                                                     | 4–29                                   |
| APP | PENDIXES                                                                                                 |                                        |
| A.  | ASSEMBLER REFERENCES                                                                                     |                                        |
|     | CHECK-OFF TABLE TERMS                                                                                    | A-20                                   |
| B.  | CHARACTER SET CODE REFERENCES                                                                            |                                        |
| C.  | MATH REFERENCES                                                                                          |                                        |
|     | FLOATING-POINT MATH Floating-Point Addition Floating-Point Division Floating-Point Multiplication        | C-10<br>C-11<br>C-12<br>C-13           |
| D.  | SOURCE CORRECTIONS                                                                                       |                                        |
|     | GENERAL                                                                                                  | D-1                                    |
|     | PARAM                                                                                                    | D-2                                    |
|     | SEQ .                                                                                                    | D-6                                    |
|     | REC                                                                                                      | D-7                                    |
|     | SKI                                                                                                      | D-8                                    |
| E.  | SYSTEM VARIABLE SYMBOLS                                                                                  |                                        |
| F.  | ATTRIBUTE REFERENCES                                                                                     |                                        |
|     | Type Attributes Length Attributes Scale Attributes Integer Attributes Count Attributes Number Attributes | F-2<br>F-4<br>F-5<br>F-5<br>F-5<br>F-6 |

**GLOSSARY** 

**USER COMMENT SHEET** 

### **TABLES**

| A-1. | Instruction Formats                                           | A-1  |
|------|---------------------------------------------------------------|------|
| A-2. | Instruction Repertoire                                        | A-3  |
| A-3. | Extended Mnemonic Branch Codes                                | A-19 |
| A-4. | Summary of Operators                                          | A-20 |
| A-5. | Comparison of Terms                                           | A-20 |
| A6.  | Characteristics of Constant and Storage Definition Type Codes | A-2  |
| A-7. | Macro and Proc Format Comparison                              | A-22 |
| A-8. | Check-off Table Terms                                         | A-23 |
| B–1. | Punched Card, ASCII, and EBCDIC Codes                         | B-1  |
| B-2. | 90/30 EBCDIC Code Chart                                       | B-6  |
| B-3. | ASCII Character Code Chart                                    | B-7  |
| C-1. | Comparison of Numeric Expressions                             | C-1  |
| C-2. | Hexadecimal-Decimal Integer Conversion                        | C-2  |
| C-3. | Hexadecimal-Decimal Fraction Conversion                       | C-6  |
| C-4. | Hexadecimal Addition and Subtraction Table                    | C-7  |
| C-5. | Powers of 16                                                  | C-8  |
| C-6. | Powers of 2                                                   | C-9  |
| F–1. | Valid Attribute Reference Applications                        | F-2  |
| F2   | Type Attributes of Symbols                                    | F3   |

1. General Information

#### ASSEMBLER OVERVIEW

The SPERRY UNIVAC Operating System/3 (OS/3) assembler permits highly-efficient, machine-instruction programs to be written in symbolic form. The assembler consists of an instruction translator and a macro facility. The instruction translator converts symbolic instructions to machine instructions on a one-to-one basis. The macro facility allows a subroutine to be coded, assigned a name, stored in a permanent library, and then to be included in a source program by a simple reference to the subroutine's name in a single instruction. The macro facility greatly reduces the amount of repetitive coding required for routines used frequently within a program or in many different programs.

The assembler accepts source-image input from punched cards, magnetic tape, and disc. It reads source statements and produces a relocatable object module. The object module can then be linked to other object modules to form one load module that is suitable for loading and execution on a SPERRY UNIVAC 90/30 System.

A set of assembler directives is provided to aid you in your program organization and in directing the course of an assembly. All assembly runs produce a printed listing that lists source code, object code, label cross-references, cross-references, and, when necessary, error diagnostics. The final error statement message, which gives the total number of statements flagged in the assembly, is also displayed on the console upon completion of the assembly.

#### JOB CONTROL REQUIREMENTS

The job control statements required to assemble, linkage edit, and execute are:

| /./. JOBjo<br>/./. A.S.ML.O<br>/\$               | bin,a,m,e                                        |             |             | NAME JOB                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |
|--------------------------------------------------|--------------------------------------------------|-------------|-------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|                                                  | 1                                                |             | <u> </u>    | ASSEMBLE LITNE FIXECUTIF                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |
|                                                  | 1 [                                              |             |             | THE PERSON NAMED IN THE PE |
|                                                  | <del>                                     </del> | <del></del> |             | START OF DIATA                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
| 1                                                |                                                  |             |             | <u> </u>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |
|                                                  |                                                  |             | <u>L </u>   |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |
| >, , S10,U,RC                                    | E. Co                                            | DE PROGRAM  | <del></del> |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |
| 4-1-1-1-1                                        | 1111                                             |             | <del></del> | <del> </del>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
|                                                  |                                                  |             |             | <del></del>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
| /*                                               |                                                  |             | <del></del> | - END OF DATA                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
| 18                                               |                                                  |             | <u> </u>    | END OF JOB                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
| /./F.I IN                                        |                                                  |             |             | , GLOSE CARO READER                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
|                                                  |                                                  |             |             | <del> </del>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
| <del></del>                                      | <del>┠┺┵┸┸</del> ╂┪                              | <del></del> | <u> </u>    |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |
| <del>                                     </del> |                                                  | <del></del> | <u> </u>    |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |
|                                                  |                                                  |             | <u> </u>    |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |

#### ASSEMBLER CODING FORM

Using an assembler coding form eases the job of writing the program, both for yourself and for the keypunch operator, who must prepare the punched card deck from your written program. Columns 9 and 15 are ruled to remind you that the symbol and operation fields must be terminated by at least one blank.

#### Symbol Field

The first eight columns of the assembler coding form may contain a symbol. An asterisk (\*) indicates that this coding line does not contain instructions and that it contains only comments. The rules for using the symbol field are:

- 1. The symbol must start in column 1.
- 2. The symbol must begin with an alphabetic character or special letter.
- 3. The symbol must not exceed eight characters in length.
- 4. The symbol must not contain embedded blanks or other special characters.
- 5. The field must be terminated by a blank.

#### **Operation Field**

The operation code is written in the operation field (columns 10 through 14). These codes specify the operation to be performed. The rules for using this field are:

- 1. The operation code must not contain embedded blanks.
- 2. The operation code must be written exactly as shown in the list of mnemonics for application instructions, directives, and macro or proc instructions.
- 3. The operation field must be terminated by a blank.
- 4. The operation code must not start in column 1.

#### Operand Field

The operand field begins in column 16 and usually ends in or before column 71. The operands that form part of the assembler statements are written in this field. The rules for using this field are:

- 1. The operand field is terminated by a blank that is not enclosed by apostrophes.
- 2. Operands may be continued onto the next line by placing a nonblank character in column 72. Up to two continuation lines are permitted.
- 3. Continuation lines start in column 16.

#### **Comment Field**

Operand specification is usually completed by column 40, thus leaving columns 41 through 71 free for comments. There must be at least one blank between the end of the operand specification and the start of the comments. Long comments can be entered by coding an \* in column 1.

#### **Continuation Column**

When the operand specification is continued onto the next line, a nonblank character must be written in column 72. Do not confuse this with continuing a comment. An operand specification can be continued for a total of three lines. The second and third continuation lines start in column 16.

#### Sequence Field

Columns 73 through 80 may be used for entering sequence numbers. This is done by assigning consecutive numbers to each line of coding and is useful for reassembling the card deck if it should be dropped.

#### **READING INSTRUCTION NOTATIONS**

Throughout this manual, notations are used to describe the general forms of programmer-written and computergenerated formats. A complete consolidated listing of all the notations is given in A.1.

#### **Assembler Application Instruction Notations**

There are six forms of assembler application instructions:

| RR | _ | Register-to-register                                             |
|----|---|------------------------------------------------------------------|
| RX | _ | Register-to-indexed-storage or storage-to-indexed-register       |
| RS |   | Register-to-nonindexed-storage or storage-to-nonindexed-register |
| SI | _ | Storage immediate                                                |
| SS | _ | Storage-to-storage (type SS1)                                    |
| ss |   | Storage-to-storage (type SS2)                                    |

All of the assembler application instructions and other information are explained in formats that you can write and in the assembler format that generates the machine coding. The following assembler application move instruction (MVC) is an SS1 type:

#### **Explicit Format:**

| LABEL    | $\Delta$ OPERATION $\Delta$ | OPERAND                                                                           |  |  |
|----------|-----------------------------|-----------------------------------------------------------------------------------|--|--|
| [symbol] | MVC                         | d <sub>1</sub> (I <sub>1</sub> ,b <sub>1</sub> ),d <sub>2</sub> (b <sub>2</sub> ) |  |  |

Implicit Format:

| LABEL    | $\Delta$ OPERATION $\Delta$ | OPERAND                                         |
|----------|-----------------------------|-------------------------------------------------|
| [symbol] | MVC                         | s <sub>1</sub> (I <sub>1</sub> ),s <sub>2</sub> |

After this application instruction is assembled, it is in the following form:



Table A—1 shows the six formats as generated by the assembler in machine code, as well as the explicit and implicit formats for the programmer coding.

#### **Notation Rules and Meanings**

The following conventions are used in application instruction, assembler directive, macro instruction, proc, and control statement formats:

Optional information is enclosed in brackets [] and may be specified or omitted.

For example:

[symbol]

Braces { } indicate multiple options, at least one of which must be chosen.

For example:

PRINT 
$$\left\{ \begin{array}{c} ON \\ OFF \end{array} \right\}$$

Braces within brackets signify that one of the options must be chosen if that operand is specified.

For example:

When given a choice of multiple options, the option that is shaded is the default option and indicates the choice that is made by the system if you do not specify one of the options.

For example:

Uppercase letters, terms, and punctuation marks indicate information that must be coded exactly as shown.

For example:

Mnemonic codes MVN, PACK, and CLC are uppercase.

Lowercase letters and terms indicate variables that are supplied by you.

For example:

[symbol]

An ellipsis, a series of three periods, indicates that a series of entries may be coded.

For example:

$$r,[,r_2,...,r_n]$$

Keyword parameters may be coded in any order.

For example:

```
IOROUT=LOAD,BLKSIZE=512,RECFORM=FIXBLK BLKSIZE=512,IOROUT=LOAD,RECFORM=FIXBLK
```

Positional parameters must be coded in the order shown. Commas are required after each positional parameter except the last. When a positional parameter is omitted from a series of positional parameters, the comma must be retained to indicate the omission.

For example:

```
// JOB Q003,,30,8000,C000
// JOB Q003,,30,8000
```

Throughout this book, the register notations R0 through R15 represent the registers 0 through 15.

For example:

BALR R2,R3

2. BAL Application Instructions

A

|        |                                                                                                             | General        |                          | Possible                                                                | e Program Exceptions                                                                                 |  |
|--------|-------------------------------------------------------------------------------------------------------------|----------------|--------------------------|-------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------|--|
| OPCODE |                                                                                                             | FORMAT<br>TYPE | OBJECT<br>INST.<br>LGTH. | ADDRESSING DATA (INVALID SIGN/DIGIT)                                    | PROTECTION SIGNIFICANCE                                                                              |  |
| MNEM.  | HEX.                                                                                                        | .,,,_          | (BYTES)                  | DECIMAL DIVIDE                                                          | SPECIFICATION:                                                                                       |  |
| Α      | 5A                                                                                                          | RX             | 4                        | DECIMAL OVERFLOW  EXECUTE                                               | NOT A FLOATING-POINT REGISTER OP 1 NOT ON HALF-WORD BOUNDARY                                         |  |
|        | Condition Codes                                                                                             |                |                          | EXPONENT OVERFLOW  EXPONENT UNDERFLOW                                   | OP 2 NOT ON HALF-WORD BOUNDAR' OP 2 NOT ON FULL-WORD BOUNDAR'                                        |  |
| IF RE  | IF RESULT = 0, SET TO 0  IF RESULT < 0, SET TO 1  IF RESULT > 0, SET TO 2  IF OVERFLOW, SET TO 3  UNCHANGED |                |                          | FIXED-POINT DIVIDE FIXED-POINT OVERFLOW FLOATING-POINT DIVIDE OPERATION | OP 2 NOT ON DOUBLE WORD BOUNDARY OP 1 NOT EVEN NUMBERED REGISTER OP 1 NOT ODD NUMBERED REGISTER NONE |  |

#### Function:

Causes the value of operand 2, a full word in main storage, to be algebraically added to operand 1, a general register; the results are placed in operand 1.

#### **Explicit Format:**

| LABEL    | $\Delta$ OPERATION $\Delta$ | OPERAND                                                          |
|----------|-----------------------------|------------------------------------------------------------------|
| [symbol] | Α                           | r <sub>1</sub> ,d <sub>2</sub> (x <sub>2</sub> ,b <sub>2</sub> ) |
|          |                             |                                                                  |

#### Implicit Format:

| LABEL    | $\Delta$ OPERATION $\Delta$ | OPERAND                                          |
|----------|-----------------------------|--------------------------------------------------|
| [symbol] | Α                           | r <sub>1</sub> ,s <sub>2</sub> (x <sub>2</sub> ) |
|          |                             |                                                  |

- Operand 2 must be on a full-word boundary address.
- Operand 2 must contain data in fixed-point binary format.
- A fixed-point overflow condition is produced when a value greater than 2<sup>31</sup>—1 or —2<sup>31</sup> is reached in operand 1 (r<sub>1</sub>). After overflow, the sign and value of the result are incorrect.
- The contents of operand 2 remain unchanged.

### AD\*

#### Floating Point

|       |                                                                                                                              | General           |                                     | Possible                                                                        | e Program Exceptions                                                                                                          |
|-------|------------------------------------------------------------------------------------------------------------------------------|-------------------|-------------------------------------|---------------------------------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------|
| OPCO  |                                                                                                                              | FORMAT<br>TYPE    | OBJECT<br>INST.<br>LGTH.<br>(BYTES) | ADDRESSING DATA (INVALID SIGN/DIGIT) DECIMAL DIVIDE                             | SPECIFICATION:                                                                                                                |
| AD    | 6A<br>Conc                                                                                                                   | RX<br>lition Code | 4<br>s                              | DECIMAL OVERFLOW EXECUTE EXPONENT OVERFLOW EXPONENT UNDERFLOW                   | NOT A FLOATING-POINT REGISTER  OP 1 NOT ON HALF-WORD BOUNDARY  OP 2 NOT ON HALF-WORD BOUNDARY  OP 2 NOT ON FULL-WORD BOUNDARY |
| IF RE | Condition Codes  IF RESULT = 0, SET TO 0  IF RESULT < 0, SET TO 1  IF RESULT > 0, SET TO 2  IF OVERFLOW, SET TO 3  UNCHANGED |                   |                                     | ☐ FIXED-POINT DIVIDE ☐ FIXED-POINT OVERFLOW ☐ FLOATING-POINT DIVIDE ■ OPERATION | OP 2 NOT ON DOUBLE-WORD BOUNDARY OP 1 NOT EVEN NUMBERED REGISTER OP 1 NOT ODD NUMBERED REGISTER NONE                          |

#### Function:

Causes the contents of the double word in storage specified by operand 2 to be algebraically added to the contents of the double-word register specified by operand 1  $(r_1)$ . The sum is normalized and placed in the operand 1  $(r_1)$  register.

#### **Explicit Format:**

| LABEL    | $\Delta$ operation $\Delta$ | OPERAND              |
|----------|-----------------------------|----------------------|
| [symbol] | AD                          | $r_1, d_2(x_2, b_2)$ |
|          |                             |                      |

#### Implicit Format:

| LABEL    | $\Delta$ OPERATION $\Delta$ | OPERAND                                          |  |  |  |
|----------|-----------------------------|--------------------------------------------------|--|--|--|
| [symbol] | AD                          | r <sub>1</sub> ,s <sub>2</sub> (x <sub>2</sub> ) |  |  |  |
|          |                             |                                                  |  |  |  |

AD is a featured instruction. If you attempt to issue this instruction to a processor which does not have the control feature installed, you cause an operation program exception.

**ADR\*** 

Floating Point

|        |                       | General                                                       |            | Possible                                                                | Program Exceptions                                                                                   |  |
|--------|-----------------------|---------------------------------------------------------------|------------|-------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------|--|
| OPCODE |                       | OBJECT FORMAT INST. TYPE LGTH.                                |            | ☐ ADDRESSING ☐ DATA (INVALID SIGN/DIGIT)                                | PROTECTION SIGNIFICANCE                                                                              |  |
| MNEM.  | HEX.                  | ,,,,                                                          | (BYTES)    | DECIMAL DIVIDE                                                          | SPECIFICATION:                                                                                       |  |
| ADR    | 2A                    | RR                                                            | 2          | ☐ EXECUTE                                                               | NOT A FLOATING-POINT REGISTER OP 1 NOT ON HALF-WORD BOUNDARY                                         |  |
|        | Conc                  | lition Code                                                   | s          | EXPONENT OVERFLOW  EXPONENT UNDERFLOW                                   | OP 2 NOT ON HALF-WORD BOUNDARY OP 2 NOT ON FULL-WORD BOUNDARY OP 2 NOT ON DOUBLE-WORD                |  |
| IF RE  | SULT<br>SULT<br>/ERFL | = 0, SET TO<br>< 0, SET TO<br>> 0, SET TO<br>OW, SET TO<br>ED | ) 1<br>) 2 | FIXED-POINT DIVIDE FIXED-POINT OVERFLOW FLOATING-POINT DIVIDE OPERATION | OP 2 NOT ON DOUBLE-WORD BOUNDARY OP 1 NOT EVEN NUMBERED REGISTER OP 1 NOT ODD NUMBERED REGISTER NONE |  |

#### Function:

Causes the contents of the double-word register specified by operand 2 ( $r_2$ ) to be algebraically added to the contents of the double-word register specified by operand 1 ( $r_1$ ). The sum is normalized and placed in the operand 1 ( $r_1$ ) register.

#### **Explicit and Implicit Format:**

| LABEL    | $\Delta$ OPERATION $\Delta$ | OPERAND                        |  |  |
|----------|-----------------------------|--------------------------------|--|--|
| [symbol] | ADR                         | r <sub>1</sub> ,r <sub>2</sub> |  |  |

<sup>\*</sup> ADR is a featured instruction. If you attempt to issue this instruction to a processor which does not have the control feature installed, you cause an operation program exception.

#### AE\*

#### Floating Point

|       |                                                                                                             | General        |                                     | Possible                                                                | e Program Exceptions                                                                                 |
|-------|-------------------------------------------------------------------------------------------------------------|----------------|-------------------------------------|-------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------|
| OPCO  |                                                                                                             | FORMAT<br>TYPE | OBJECT<br>INST.<br>LGTH.<br>(BYTES) | ADDRESSING DATA (INVALID SIGN/DIGIT) DECIMAL DIVIDE                     | PROTECTION SIGNIFICANCE SPECIFICATION:                                                               |
| AE    | 7A                                                                                                          | RX             | 4                                   | DECIMAL OVERFLOW EXECUTE                                                | NOT A FLOATING-POINT REGISTER  OP 1 NOT ON HALF-WORD BOUNDARY                                        |
|       | Condition Codes                                                                                             |                |                                     | EXPONENT OVERFLOW  EXPONENT UNDERFLOW                                   | OP 2 NOT ON HALF-WORD BOUNDARY OP 2 NOT ON FULL-WORD BOUNDARY OP 2 NOT ON DOUBLE-WORD                |
| IF RE | IF RESULT = 0, SET TO 0  IF RESULT < 0, SET TO 1  IF RESULT > 0, SET TO 2  IF OVERFLOW, SET TO 3  UNCHANGED |                |                                     | FIXED-POINT DIVIDE FIXED-POINT OVERFLOW FLOATING-POINT DIVIDE OPERATION | OP 2 NOT ON DOUBLE-WORD BOUNDARY OP 1 NOT EVEN NUMBERED REGISTER OP 1 NOT ODD NUMBERED REGISTER NONE |

#### Function:

Causes the contents of the full word in storage specified by operand 2 to be algebraically added to the contents of a full word in the register specified by operand 1  $(r_1)$ . The sum is normalized and placed in the full word in the operand 1  $(r_1)$  register.

#### **Explicit Format:**

| LABEL    | $\Delta$ OPERATION $\Delta$ | OPERAND            |
|----------|-----------------------------|--------------------|
| [symbol] | AE                          | $r_1,d_2(x_2,b_2)$ |
|          |                             |                    |

#### Implicit Format:

| LABEL    | $\Delta$ OPERATION $\Delta$ | OPERAND                                          |
|----------|-----------------------------|--------------------------------------------------|
| [symbol] | AE                          | r <sub>1</sub> ,s <sub>2</sub> (x <sub>2</sub> ) |
|          |                             |                                                  |

<sup>\*</sup> AE is a featured instruction. If you attempt to issue this instruction to a processor which does not have the control feature installed, you cause an operation program exception.

**AER\*** 

Floating Point

|       |                                                                                                         | General      |         | Possible                                                                | e Program Exceptions                                                                                 |  |
|-------|---------------------------------------------------------------------------------------------------------|--------------|---------|-------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------|--|
| ОРСО  | DE                                                                                                      | E FORMAT INS |         | ☐ ADDRESSING ☐ DATA (INVALID SIGN/DIGIT)                                | PROTECTION SIGNIFICANCE                                                                              |  |
| MNEM. | HEX.                                                                                                    | 1112         | (BYTES) | DECIMAL DIVIDE                                                          | SPECIFICATION:                                                                                       |  |
| AER   | 3A                                                                                                      | RR           | 2       | DECIMAL OVERFLOW EXECUTE                                                | NOT A FLOATING-POINT REGISTER  OP 1 NOT ON HALF-WORD BOUNDARY                                        |  |
|       | Condition Codes                                                                                         |              |         | EXPONENT OVERFLOW  EXPONENT UNDERFLOW                                   | OP 2 NOT ON HALF-WORD BOUNDARY OP 2 NOT ON FULL-WORD BOUNDARY OP 2 NOT ON DOUBLE-WORD                |  |
| IF RE | IF RESULT = 0, SET TO 0 IF RESULT < 0, SET TO 1 IF RESULT > 0, SET TO 2 IF OVERFLOW, SET TO 3 UNCHANGED |              |         | FIXED-POINT DIVIDE FIXED-POINT OVERFLOW FLOATING-POINT DIVIDE OPERATION | OP 2 NOT ON DOUBLE-WORD BOUNDARY OP 1 NOT EVEN NUMBERED REGISTER OP 1 NOT ODD NUMBERED REGISTER NONE |  |

#### Function:

Causes the contents of a full word in the register specified by operand 2 ( $r_2$ ) to be algebraically added to a full word in the register specified by operand 1 ( $r_1$ ). The sum is normalized and placed in the operand 1 ( $r_1$ ) register.

#### **Explicit and Implicit Format:**

| LABEL    | $\Delta$ OPERATION $\Delta$ | OPERAND                        | _ |
|----------|-----------------------------|--------------------------------|---|
| [symbol] | AER                         | r <sub>1</sub> ,r <sub>2</sub> |   |
|          |                             |                                |   |

AER is a featured instruction. If you attempt to issue this instruction to a processor which does not have the control feature
installed, you cause an operation program exception.

### AH

|       |                                                                                                             | General                        |         | Possible                                                                | e Program Exceptions                                                                                 |
|-------|-------------------------------------------------------------------------------------------------------------|--------------------------------|---------|-------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------|
| орсо  | DE                                                                                                          | OBJECT FORMAT INST. TYPE LGTH. |         | ADDRESSING DATA (INVALID SIGN/DIGIT)                                    | PROTECTION SIGNIFICANCE                                                                              |
| MNEM. | HEX.                                                                                                        | ,,,,,                          | (BYTES) | DECIMAL DIVIDE                                                          | SPECIFICATION:                                                                                       |
| АН    | 4A                                                                                                          | RX                             | 4       | DECIMAL OVERFLOW EXECUTE                                                | OP 1 NOT ON HALF WORD BOUNDARY                                                                       |
|       | Condition Codes                                                                                             |                                | s       | EXPONENT OVERFLOW  EXPONENT UNDERFLOW                                   | OP 2 NOT ON HALF-WORD BOUNDARY OP 2 NOT ON FULL-WORD BOUNDARY OP 2 NOT ON DOUBLE-WORD                |
| IF RE | IF RESULT = 0, SET TO 0  IF RESULT < 0, SET TO 1  IF RESULT > 0, SET TO 2  IF OVERFLOW, SET TO 3  UNCHANGED |                                |         | FIXED-POINT DIVIDE FIXED-POINT OVERFLOW FLOATING-POINT DIVIDE OPERATION | OP 2 NOT ON DOUBLE-WORD BOUNDARY OP 1 NOT EVEN NUMBERED REGISTER OP 1 NOT ODD NUMBERED REGISTER NONE |

#### Function:

Causes the value of operand 2, a half word in main storage, to be algebraically added to operand 1, a general register; the results are placed in operand 1.

#### **Explicit Format:**

| LABEL    | $\Delta$ OPERATION $\Delta$ | OPERAND                                                          |    |  |
|----------|-----------------------------|------------------------------------------------------------------|----|--|
| [symbol] | АН                          | r <sub>1</sub> ,d <sub>2</sub> (x <sub>2</sub> ,b <sub>2</sub> ) | e+ |  |

#### Implicit Format:

| LABEL    | $\Delta$ OPERATION $\Delta$ | OPERAND                                          |  |  |
|----------|-----------------------------|--------------------------------------------------|--|--|
| [symbol] | АН                          | r <sub>1</sub> ,s <sub>2</sub> (x <sub>2</sub> ) |  |  |
|          |                             |                                                  |  |  |

- Operand 2 must be on a half-word boundary address.
- Operand 2 must contain data in fixed-point binary format.
- A fixed-point overflow condition is produced when a value greater than  $2^{31}$ —1 or  $-2^{31}$  is reached in operand 1 (r<sub>1</sub>). After overflow, the sign and value of the result are incorrect.
- The contents of operand 2 remain unchanged.

|       |                                                                                                         | General                        |         | Possible                                                                      | e Program Exceptions                                                                                 |  |
|-------|---------------------------------------------------------------------------------------------------------|--------------------------------|---------|-------------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------|--|
| орсо  | DE                                                                                                      | OBJECT FORMAT INST. TYPE LGTH. |         | ■ ADDRESSING □ DATA (INVALID SIGN/DIGIT)                                      | PROTECTION SIGNIFICANCE                                                                              |  |
| MNEM. | HEX.                                                                                                    |                                | (BYTES) | DECIMAL DIVIDE                                                                | SPECIFICATION:                                                                                       |  |
| AI    | 9A                                                                                                      | SI                             | 4       | DECIMAL OVERFLOW EXECUTE                                                      | OP 1 NOT ON HALF-WORD BOUNDARY                                                                       |  |
|       | Condition Codes                                                                                         |                                |         | EXPONENT OVERFLOW  EXPONENT UNDERFLOW                                         | OP 2 NOT ON HALF-WORD BOUNDARY OP 2 NOT ON FULL-WORD BOUNDARY OP 2 NOT ON DOUBLE-WORD                |  |
| IF RE | IF RESULT = 0, SET TO 0 IF RESULT < 0, SET TO 1 IF RESULT > 0, SET TO 2 IF OVERFLOW, SET TO 3 UNCHANGED |                                |         | FIXED-POINT DIVIDE FIXED-POINT OVERFLOW STORM FLOATING-POINT DIVIDE OPERATION | OP 2 NOT ON DOUBLE-WORD BOUNDARY OP 1 NOT EVEN NUMBERED REGISTER OP 1 NOT ODD NUMBERED REGISTER NONE |  |

#### Function:

Causes the value of operand 2, immediate data, to be algebraically added to operand 1, a half word in main storage; the results are placed in operand 1.

#### **Explicit Format:**

| LABEL    | $\Delta$ OPERATION $\Delta$ | OPERAND                                         |
|----------|-----------------------------|-------------------------------------------------|
| [symbol] | AI                          | d <sub>1</sub> (b <sub>1</sub> ),i <sub>2</sub> |
|          |                             |                                                 |

#### Implicit Format:

| LABEL    | $\Delta$ OPERATION $\Delta$ | OPERAND                         |  |  |
|----------|-----------------------------|---------------------------------|--|--|
| [symbol] | Al                          | \$ <sub>1</sub> ,i <sub>2</sub> |  |  |

- Operand 1 must be on a half-word boundary address.
- Operand 1 must contain data in fixed-point binary format.
- A fixed-point overflow condition is produced when a value greater than 2<sup>15</sup>—1 or —2<sup>15</sup> is reached in operand 1. After overflow, the sign and value of the result are incorrect.
- The maximum value for operand 2 ( $i_2$ ) is +127 or -128.

### AL\*

|                                     | General         |                |                          | Possible Program Exceptions                                                     |                                                                                                 |  |
|-------------------------------------|-----------------|----------------|--------------------------|---------------------------------------------------------------------------------|-------------------------------------------------------------------------------------------------|--|
| OPCO                                | DE              | FORMAT<br>TYPE | OBJECT<br>INST.<br>LGTH. | ADDRESSING DATA (INVALID SIGN/DIGIT)                                            | PROTECTION SIGNIFICANCE                                                                         |  |
| MNEM.                               | HEX.            |                | (BYTES)                  | DECIMAL DIVIDE                                                                  | SPECIFICATION:                                                                                  |  |
| AL                                  | 5E              | RX             | 4                        | ☐ DECIMAL OVERFLOW ☐ EXECUTE                                                    | OP 1 NOT ON HALF-WORD BOUNDARY                                                                  |  |
|                                     | Condition Codes |                |                          | EXPONENT OVERFLOW  EXPONENT UNDERFLOW                                           | OP 2 NOT ON HALF-WORD BOUNDARY OP 2 NOT ON FULL-WORD BOUNDARY                                   |  |
| SET TO 0 SET TO 1 SET TO 2 SET TO 3 |                 |                |                          | ☐ FIXED-POINT DIVIDE ☐ FIXED-POINT OVERFLOW ☐ FLOATING-POINT DIVIDE ■ OPERATION | OP 2 NOT ON DOUBLE-WORD BOUNDARY OP 1 NOT EVEN NUMBERED REGISTER OP 1 NOT ODD NUMBERED REGISTER |  |
| SEE OP                              | ER. CO          | NSIDERAT       | IONS                     |                                                                                 | ☐ NONE                                                                                          |  |

#### Function:

Causes the contents of operand 2, a full word in storage, to be logically added to the contents of the full word in the operand 1  $(r_1)$  register. The sum is placed in operand 1  $(r_1)$ .

#### **Explicit Format:**

| LABEL    | $\Delta$ OPERATION $\Delta$ | OPERAND                                                          |  |  |
|----------|-----------------------------|------------------------------------------------------------------|--|--|
| [symbol] | AL                          | r <sub>1</sub> ,d <sub>2</sub> (x <sub>2</sub> ,b <sub>2</sub> ) |  |  |

#### Implicit Format:

| LABEL    | $\Delta$ OPERATION $\Delta$ | OPERAND                                          |
|----------|-----------------------------|--------------------------------------------------|
| [symbol] | AL                          | r <sub>1</sub> ,s <sub>2</sub> (x <sub>2</sub> ) |

- Logical addition is performed by adding all 32 bits of each operand.
- The contents of operand 2 remain unchanged.
- Operand 2 must be a full word, in storage, on a full-word boundary.

<sup>\*</sup> AL is a featured instruction. If you attempt to issue this instruction to a processor which does not have the control feature installed, you cause an operation program exception.

AL\*

PAGE

## ■ The condition code is set:

- to zero if result is zero; no carryout of most significant bit;
- to 1 if result is not zero; no carryout of most significant bit;
- to 2 if result is zero; carryout of most significant bit; or
- to 3 if result is not zero; carryout of most significant bit.

PAGE

#### General Possible Program Exceptions **OBJECT** ADDRESSING PROTECTION OPCODE FORMAT INST. ☐ DATA (INVALID SIGN/DIGIT) ☐ SIGNIFICANCE TYPE LGTH. DECIMAL DIVIDE SPECIFICATION: MNEM. (BYTES) HEX. ☐ DECIMAL OVERFLOW NOT A FLOATING-POINT REGISTER ALR 1E RR ☐ EXECUTE OP 1 NOT ON HALF-WORD BOUNDARY ☐ EXPONENT OVERFLOW OP 2 NOT ON HALF-WORD BOUNDARY **Condition Codes** ☐ EXPONENT UNDERFLOW OP 2 NOT ON FULL-WORD BOUNDARY FIXED-POINT DIVIDE OP 2 NOT ON DOUBLE-WORD SET TO 0 BOUNDARY ☐ FIXED-POINT OVERFLOW SET TO 1 OP 1 NOT EVEN NUMBERED REGISTER ☐ FLOATING-POINT DIVIDE SET TO 2 SET TO 3 OP 1 NOT ODD NUMBERED REGISTER **OPERATION** ☐ NONE SEE OPER. CONSIDERATIONS

#### Function:

Causes the contents of the operand 1  $(r_1)$  and operand 2  $(r_2)$  registers to be logically added. The sum is placed in operand 1  $(r_1)$ .

## **Explicit and Implicit Format:**

| LABEL    | $\Delta$ OPERATION $\Delta$ | OPERAND                        |
|----------|-----------------------------|--------------------------------|
| [symbol] | ALR                         | r <sub>1</sub> ,r <sub>2</sub> |

- Logical addition is performed by adding all 32 bits of each operand.
- The contents of operand 2 (r<sub>2</sub>) remain unchanged.
- The condition code is set:
  - to zero if result is zero; no carryout of most significant bit;
  - to 1 if result is not zero; no carryout of most significant bit;
  - to 2 if result is zero; carryout of most significant bit; or
  - to 3 if result is not zero; carryout of most significant bit.

<sup>\*</sup> ALR is a featured instruction. If you attempt to issue this instruction to a processor which does not have the control feature installed, you cause an operation program exception.

FIXED-POINT DIVIDE

OPERATION

☐ FIXED-POINT OVERFLOW

☐ FLOATING-POINT DIVIDE

PAGE

BOUNDARY

OP 2 NOT ON DOUBLE-WORD

OP 1 NOT EVEN NUMBERED REGISTER

OP 1 NOT ODD NUMBERED REGISTER

☐ NONE

### Function:

UNCHANGED

OPCODE

MNEM.

AP

HEX.

FA

General

FORMAT

TYPE

SS

**Condition Codes** 

IF RESULT = 0, SET TO 0
IF RESULT < 0, SET TO 1

■ IF RESULT > 0, SET TO 2

IF OVERFLOW, SET TO 3

OBJECT

INST.

LGTH.

6

(BYTES)

Algebraically adds the contents of operand 2 (a packed number in main storage) to operand 1 (also a packed number in main storage). The result is stored in operand 1.

## **Explicit Format:**

| LABEL    | $\Delta$ OPERATION $\Delta$ | OPERAND                                                                                           |
|----------|-----------------------------|---------------------------------------------------------------------------------------------------|
| [symbol] | АР                          | d <sub>1</sub> (I <sub>1</sub> ,b <sub>1</sub> ),d <sub>2</sub> (I <sub>2</sub> ,b <sub>2</sub> ) |

#### Implicit Format:

| LABEL    | $\Delta$ OPERATION $\Delta$ | OPERAND                                                           |
|----------|-----------------------------|-------------------------------------------------------------------|
| [symbol] | АР                          | s <sub>1</sub> (I <sub>1</sub> ),s <sub>2</sub> (I <sub>2</sub> ) |

- All signs and digits are checked for validity and the sign of the result is determined algebraically.
- A zero result has a positive sign when the operation is completed without overflow.
- Operand 1 and operand 2 must be packed numbers.
- When most significant digits are lost because of overflow, the partial result has the sign that the correct result would have had.

PAGE

AP

- If operand 2 is shorter than operand 1, operand 2 is extended with zero digits.
- An overflow condition results if the capacity of the operand 1 field is exceeded by the result or if the carryout of the most significant digit position of the result field is lost.
- Operand 1 and operand 2 may overlap if their least significant bytes coincide. This makes it possible to add a number to itself.

AR

| General                 |                                                                                                         |                |                          | Possible Program Exceptions                                             |                                                                                                      |  |
|-------------------------|---------------------------------------------------------------------------------------------------------|----------------|--------------------------|-------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------|--|
| орсо                    | DE                                                                                                      | FORMAT<br>TYPE | OBJECT<br>INST.<br>LGTH. | ADDRESSING DATA (INVALID SIGN/DIGIT)                                    | PROTECTION SIGNIFICANCE                                                                              |  |
| MNEM.                   | HEX.                                                                                                    | ,,,,_          | (BYTES)                  | DECIMAL DIVIDE                                                          | SPECIFICATION:                                                                                       |  |
| AR                      | 1A                                                                                                      | RR             | 2                        | DECIMAL OVERFLOW  EXECUTE                                               | NOT A FLOATING-POINT REGISTER  OP 1 NOT ON HALF-WORD BOUNDARY                                        |  |
| Condition Codes         |                                                                                                         |                |                          | EXPONENT OVERFLOW  EXPONENT UNDERFLOW                                   | OP 2 NOT ON HALF-WORD BOUNDAR OP 2 NOT ON FULL-WORD BOUNDAR OP 2 NOT ON DOUBLE-WORD                  |  |
| IF RE<br>IF RE<br>IF OV | IF RESULT = 0, SET TO 0 IF RESULT < 0, SET TO 1 IF RESULT > 0, SET TO 2 IF OVERFLOW, SET TO 3 UNCHANGED |                |                          | FIXED-POINT DIVIDE FIXED-POINT OVERFLOW FLOATING-POINT DIVIDE OPERATION | OP 2 NOT ON DOUBLE-WORD BOUNDARY OP 1 NOT EVEN NUMBERED REGISTER OP 1 NOT ODD NUMBERED REGISTER NONE |  |

## Function:

Causes the value of operand 2  $(r_2)$  to be algebraically added to the value of operand 1  $(r_1)$ . The results are placed in operand 1.

**Explicit and Implicit Format:** 

| LABEL    | $\Delta$ operation $\Delta$ | OPERAND                        |
|----------|-----------------------------|--------------------------------|
| [symbol] | AR                          | r <sub>1</sub> ,r <sub>2</sub> |

- A fixed-point overflow condition is produced when a value greater than 2<sup>31</sup>—1 or —2<sup>31</sup> is reached in operand 1. After overflow, the sign and value of the result are incorrect.
- The contents of the register for operand 2 (r₂) remain unchanged.

## **AU\***

## **Floating Point**

|       |                                                                                                         | General |                          | Possible Program Exceptions                                             |                                                                                                      |  |
|-------|---------------------------------------------------------------------------------------------------------|---------|--------------------------|-------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------|--|
| орсо  | OPCODE FOR                                                                                              |         | OBJECT<br>INST.<br>LGTH. | ADDRESSING DATA (INVALID SIGN/DIGIT)                                    |                                                                                                      |  |
| MNEM. | HEX.                                                                                                    |         | (BYTES)                  | DECIMAL DIVIDE                                                          | SPECIFICATION:                                                                                       |  |
| ΑU    | 7E                                                                                                      | RX      | 4                        | DECIMAL OVERFLOW EXECUTE                                                | NOT A FLOATING-POINT REGISTER OP 1 NOT ON HALF-WORD BOUNDARY                                         |  |
|       | Condition Codes                                                                                         |         |                          | EXPONENT OVERFLOW  EXPONENT UNDERFLOW                                   | OP 2 NOT ON HALF-WORD BOUNDARY OP 2 NOT ON FULL-WORD BOUNDARY OP 2 NOT ON DOUBLE-WORD                |  |
| IF RE | IF RESULT = 0, SET TO 0 IF RESULT < 0, SET TO 1 IF RESULT > 0, SET TO 2 IF OVERFLOW, SET TO 3 UNCHANGED |         |                          | FIXED-POINT DIVIDE FIXED-POINT OVERFLOW FLOATING-POINT DIVIDE OPERATION | OP 2 NOT ON DOUBLE-WORD BOUNDARY OP 1 NOT EVEN NUMBERED REGISTER OP 1 NOT ODD NUMBERED REGISTER NONE |  |

### Function:

Causes the contents of the full word in storage specified by operand 2 to be algebraically added to the contents of a full word in the register specified by operand 1  $(r_1)$ . The sum is placed in the operand 1  $(r_1)$  register.

## **Explicit Format:**

| LABEL    | $\Delta$ OPERATION $\Delta$ | OPERAND              |
|----------|-----------------------------|----------------------|
| [symbol] | AU                          | $r_1, d_2(x_2, b_2)$ |

### Implicit Format:

| LABEL    | $\Delta$ operation $\Delta$ | OPERAND                                          |
|----------|-----------------------------|--------------------------------------------------|
| [symbol] | AU                          | r <sub>1</sub> ,s <sub>2</sub> (x <sub>2</sub> ) |

## **Operational Consideration:**

■ The execution of the AU instruction is identical to that of the AE instruction, except that the sum is not normalized before being placed in operand 1.

AU is a featured instruction. If you attempt to issue this instruction to a processor which does not have the control feature installed, you cause an operation program exception.

ALIR\*

**Floating Point** 

| General                 |                      |                                                         |                          | Possible Program Exceptions                                                                            |                                                                                               |  |
|-------------------------|----------------------|---------------------------------------------------------|--------------------------|--------------------------------------------------------------------------------------------------------|-----------------------------------------------------------------------------------------------|--|
| OPCODE                  |                      | FORMAT<br>TYPE                                          | OBJECT<br>INST.<br>LGTH. | ☐ ADDRESSING ☐ DATA (INVALID SIGN/DIGIT)                                                               | PROTECTION SIGNIFICANCE                                                                       |  |
| MNEM.                   | HEX.                 | , , , , _                                               | (BYTES)                  | DECIMAL DIVIDE                                                                                         | SPECIFICATION:                                                                                |  |
| AUR                     | 3E                   | RR                                                      | 2                        | ☐ DECIMAL OVERFLOW                                                                                     | NOT A FLOATING-POINT REGISTER  OP 1 NOT ON HALF-WORD BOUNDARY                                 |  |
|                         | Cond                 | lition Code                                             | s                        | EXPONENT OVERFLOW  EXPONENT UNDERFLOW                                                                  | OP 2 NOT ON FULL-WORD BOUNDARY                                                                |  |
| IF RE<br>IF RE<br>IF OV | SULT<br>SULT<br>ERFL | = 0, SET TO<br>< 0, SET TO<br>> 0, SET TO<br>OW, SET TO | ) 1<br>) 2               | FIXED-POINT DIVIDE FIXED-POINT OVERFLOW FLOATING-POINT DIVIDE OPERATION                                | BOUNDARY  OP 1 NOT EVEN NUMBERED REGISTER  OP 1 NOT ODD NUMBERED REGISTER                     |  |
| IF RE IF RE IF RE       | Cond                 |                                                         | 0 1 0 2                  | EXPONENT OVERFLOW  EXPONENT UNDERFLOW  FIXED-POINT DIVIDE  FIXED-POINT OVERFLOW  FLOATING-POINT DIVIDE | OP 2 NOT ON HALF-WORD OP 2 NOT ON FULL-WORD OP 2 NOT ON DOUBLE-W BOUNDARY OP 1 NOT EVEN NUMBE |  |

### Function:

Causes the contents of a full word in the register specified by operand 2  $(r_2)$  to be algebraically added to a full word in the register specified by operand 1  $(r_1)$ . The sum is placed in the operand 1  $(r_1)$  register.

### **Explicit and Implicit Format:**

| LABEL    | $\Delta$ operation $\Delta$ | OPERAND                        |
|----------|-----------------------------|--------------------------------|
| [symbol] | AUR                         | r <sub>1</sub> ,r <sub>2</sub> |

## **Operational Consideration:**

■ The execution of the AUR instruction is identical to that of the AER instruction, except that the sum is not normalized before being placed in operand 1.

<sup>\*</sup> AUR is a featured instruction. If you attempt to issue this instruction to a processor which does not have the control feature installed, you cause an operation program exception.

## AW\*

### **Floating Point**

|       |                                                                                                         | General |                          | Possible Program Exceptions                                             |                                                                                                      |  |
|-------|---------------------------------------------------------------------------------------------------------|---------|--------------------------|-------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------|--|
| орсо  | DDE FORMAT                                                                                              |         | OBJECT<br>INST.<br>LGTH. | ADDRESSING DATA (INVALID SIGN/DIGIT)                                    | PROTECTION SIGNIFICANCE                                                                              |  |
| MNEM. | HEX.                                                                                                    | ,,,,    | (BYTES)                  | DECIMAL DIVIDE                                                          | SPECIFICATION:                                                                                       |  |
| AW    | 6E                                                                                                      | RX      | 4                        | DECIMAL OVERFLOW EXECUTE                                                | NOT A FLOATING POINT REGISTER  OP 1 NOT ON HALF WORD BOUNDARY                                        |  |
|       | Condition Codes                                                                                         |         |                          | EXPONENT OVERFLOW  EXPONENT UNDERFLOW                                   | OP 2 NOT ON HALF-WORD BOUNDARY OP 2 NOT ON FULL-WORD BOUNDARY                                        |  |
| IF RE | IF RESULT = 0, SET TO 0 IF RESULT < 0, SET TO 1 IF RESULT > 0, SET TO 2 IF OVERFLOW, SET TO 3 UNCHANGED |         |                          | FIXED-POINT DIVIDE FIXED-POINT OVERFLOW FLOATING-POINT DIVIDE OPERATION | OP 2 NOT ON DOUBLE-WORD BOUNDARY OP 1 NOT EVEN NUMBERED REGISTER OP 1 NOT ODD NUMBERED REGISTER NONE |  |

### Function:

Causes the contents of a double word in storage specified by operand 2 to be algebraically added to the contents of the double word in the register specified by operand 1  $(r_1)$ . The sum is placed in the double word in the register specified by operand 1  $(r_1)$ .

## **Explicit Format:**

| LABEL    | $\Delta$ OPERATION $\Delta$ | OPERAND              |
|----------|-----------------------------|----------------------|
| [symbol] | AW                          | $r_1, d_2(x_2, b_2)$ |

### Implicit Format:

| LABEL    | $\Delta$ OPERATION $\Delta$ | OPERAND                                          |
|----------|-----------------------------|--------------------------------------------------|
| [symbol] | AW                          | r <sub>1</sub> ,s <sub>2</sub> (x <sub>2</sub> ) |

#### **Operational Consideration:**

The execution of the AW instruction is identical to that of the AD instruction, except that the sum is not normalized before being placed in operand 1 (r<sub>1</sub>).

AW is a featured instruction. If you attempt to issue this instruction to a processor which does not have the control feature
installed, you cause an operation program exception.

PAGE

AWR\*

**Floating Point** 

|       |                                                                                                             | General                        |         | Possible                                                                | Program Exceptions                                                                                   |
|-------|-------------------------------------------------------------------------------------------------------------|--------------------------------|---------|-------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------|
| орсо  | DE                                                                                                          | OBJECT FORMAT INST. TYPE LGTH. |         | ☐ ADDRESSING ☐ DATA (INVALID SIGN/DIGIT)                                | PROTECTION SIGNIFICANCE                                                                              |
| MNEM. | HEX.                                                                                                        | 711.5                          | (BYTES) | DECIMAL DIVIDE                                                          | SPECIFICATION:                                                                                       |
| AWR   | 2E                                                                                                          | RR                             | 2       | DECIMAL OVERFLOW DEXECUTE                                               | NOT A FLOATING-POINT REGISTER  OP 1 NOT ON HALF-WORD BOUNDARY                                        |
|       | Condition Codes                                                                                             |                                |         | EXPONENT OVERFLOW  EXPONENT UNDERFLOW                                   | OP 2 NOT ON HALF-WORD BOUNDARY OP 2 NOT ON FULL-WORD BOUNDARY OP 2 NOT ON DOUBLE-WORD                |
| IF RE | IF RESULT = 0, SET TO 0  IF RESULT < 0, SET TO 1  IF RESULT > 0, SET TO 2  IF OVERFLOW, SET TO 3  UNCHANGED |                                |         | FIXED-POINT DIVIDE FIXED-POINT OVERFLOW FLOATING-POINT DIVIDE OPERATION | OP 2 NOT ON DOUBLE-WORD BOUNDARY OP 1 NOT EVEN NUMBERED REGISTER OP 1 NOT ODD NUMBERED REGISTER NONE |

## Function:

Causes the contents of the double-word register specified by operand 2 ( $r_2$ ) to be algebraically added to the double-word contents of operand 1 ( $r_1$ ). The sum is placed in the operand 1 ( $r_1$ ) register.

### **Explicit and Implicit Format:**

| LABEL    | $\Delta$ OPERATION $\Delta$ | OPERAND                        |
|----------|-----------------------------|--------------------------------|
| [symbol] | AWR                         | r <sub>1</sub> ,r <sub>2</sub> |

### **Operational Consideration:**

■ The execution of the AWR instruction is identical to that of the ADR instruction, except that the sum is not normalized before being placed in operand 1 (r₁).

<sup>\*</sup> AWR is a featured instruction. If you attempt to issue this instruction to a processor which does not have the control feature installed, you cause an operation program exception.

## BAL

|        |              | General                                                       |                          | Possible                                                                | e Program Exceptions                                                                                 |
|--------|--------------|---------------------------------------------------------------|--------------------------|-------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------|
| OPCODE |              | FORMAT<br>TYPE                                                | OBJECT<br>INST.<br>LGTH. | ADDRESSING DATA (INVALID SIGN/DIGIT)                                    |                                                                                                      |
| MNEM.  | HEX.         |                                                               | (BYTES)                  | DECIMAL DIVIDE                                                          | SPECIFICATION:  NOT A FLOATING-POINT REGISTER                                                        |
| BAL    | 45           | RX                                                            | 4                        | DECIMAL OVERFLOW EXECUTE                                                | OP 1 NOT ON HALF WORD BOUNDARY                                                                       |
|        | Conc         | dition Code                                                   | ·s                       | EXPONENT OVERFLOW  EXPONENT UNDERFLOW                                   | OP 2 NOT ON HALF-WORD BOUNDARY OP 2 NOT ON FULL-WORD BOUNDARY OP 2 NOT ON DOUBLE-WORD                |
| IF RE  | SULT<br>SULT | = 0, SET TO<br>< 0, SET TO<br>> 0, SET TO<br>OW, SET TO<br>ED | ) 1<br>) 2               | FIXED-POINT DIVIDE FIXED-POINT OVERFLOW FLOATING-POINT DIVIDE OPERATION | OP 2 NOT ON DOUBLE-WORD BOUNDARY OP 1 NOT EVEN NUMBERED REGISTER OP 1 NOT ODD NUMBERED REGISTER NONE |

#### Function:

Loads the address of the next sequential instruction into the register in the first operand and then branches to the location specified in the second operand. The normal sequence of instructions may be reinstated when a return branch via  $\mathbf{r}_1$  is taken. BAL is an unconditional branch instruction.

### NOTE:

Bits 32 through 39 (instruction length code, condition code, and program mask) of the current program status word (PSW) are stored in bit positions 0 through 7 of operand 1  $(r_1)$ . The return address is stored in bits 8 through 31 of operand 1  $(r_1)$ .

## **Explicit Format:**

| LABEL    | $\Delta$ OPERATION $\Delta$ | OPERAND                                                          |
|----------|-----------------------------|------------------------------------------------------------------|
| [symbol] | BAL                         | r <sub>1</sub> ,d <sub>2</sub> (x <sub>2</sub> ,b <sub>2</sub> ) |

## Implicit Format:

| LABEL    | $\Delta$ OPERATION $\Delta$ | OPERAND                                          |
|----------|-----------------------------|--------------------------------------------------|
| [symbol] | BAL                         | r <sub>1</sub> ,s <sub>2</sub> (x <sub>2</sub> ) |

**BALR** 

|                 |              | General                                                       |                          | Possible                                                                | e Program Exceptions                                                                                 |
|-----------------|--------------|---------------------------------------------------------------|--------------------------|-------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------|
| OPCODE          |              | FORMAT<br>TYPE                                                | OBJECT<br>INST.<br>LGTH. | ☐ ADDRESSING ☐ DATA (INVALID SIGN/DIGIT)                                | PROTECTION SIGNIFICANCE                                                                              |
| MNEM.           | HEX.         | 1112                                                          | (BYTES)                  | DECIMAL DIVIDE                                                          | SPECIFICATION:                                                                                       |
| BALR            | 05           | RR                                                            | 2                        | DECIMAL OVERFLOW EXECUTE                                                | OP 1 NOT ON HALF-WORD BOUNDARY                                                                       |
| Condition Codes |              |                                                               |                          | EXPONENT OVERFLOW  EXPONENT UNDERFLOW                                   | OP 2 NOT ON HALF-WORD BOUNDARY OP 2 NOT ON FULL-WORD BOUNDARY OP 2 NOT ON DOUBLE-WORD                |
| ☐ IF RE☐ IF OV  | SULT<br>SULT | = 0, SET TO<br>< 0, SET TO<br>> 0, SET TO<br>OW, SET TO<br>ED | ) 1<br>) 2               | FIXED-POINT DIVIDE FIXED-POINT OVERFLOW FLOATING-POINT DIVIDE OPERATION | OP 2 NOT ON DOUBLE-WORD BOUNDARY OP 1 NOT EVEN NUMBERED REGISTER OP 1 NOT ODD NUMBERED REGISTER NONE |

### Function:

Loads the relative address of the next sequential instruction into the first operand register and then branches to the address in the second operand register. The normal sequence of instructions may be reinstated when a return branch via  $r_1$  is taken. When the second operand  $(r_2)$  is zero, there is no branch and the next sequential instruction is executed.

### NOTE:

Bits 32 through 39 (instruction length code, condition code, and program mask) of the current program status word (PSW) are stored in bit positions 0 through 7 of operand 1 ( $r_1$ ). The return address is stored in bits 8 through 31 of operand 1 ( $r_1$ ).

## **Explicit and Implicit Format:**

| LABEL    | $\Delta$ OPERATION $\Delta$ | OPERAND                        |  |
|----------|-----------------------------|--------------------------------|--|
| [symbol] | BALR                        | r <sub>1</sub> ,r <sub>2</sub> |  |

# BAS BASR

|               |                                                                                                                   | General        | ,                                   | Possible                                                                | e Program Exceptions                                                                                                               |
|---------------|-------------------------------------------------------------------------------------------------------------------|----------------|-------------------------------------|-------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------|
| OPCO          |                                                                                                                   | FORMAT<br>TYPE | OBJECT<br>INST.<br>LGTH.<br>(BYTES) | ☐ ADDRESSING ☐ DATA (INVALID SIGN/DIGIT) ☐ DECIMAL DIVIDE               | PROTECTION SIGNIFICANCE SPECIFICATION:                                                                                             |
| BAS &<br>BASR | 4D &<br>0D                                                                                                        | RX & RR        | 4 or 2                              | ☐ DECIMAL OVERFLOW ☐ EXECUTE ☐ EXPONENT OVERFLOW ☐ EXPONENT UNDERFLOW   | □ NOT A FLOATING-POINT REGISTER □ OP 1 NOT ON HALF-WORD BOUNDARY □ OP 2 NOT ON HALF-WORD BOUNDARY □ OP 2 NOT ON FULL-WORD BOUNDARY |
| ☐ IF RE☐ IF O | ☐ IF RESULT = 0, SET TO 0 ☐ IF RESULT < 0, SET TO 1 ☐ IF RESULT > 0, SET TO 2 ☐ IF OVERFLOW, SET TO 3 ☐ UNCHANGED |                |                                     | FIXED-POINT DIVIDE FIXED-POINT OVERFLOW FLOATING-POINT DIVIDE OPERATION | OP 2 NOT ON DOUBLE-WORD BOUNDARY OP 1 NOT EVEN NUMBERED REGISTER OP 1 NOT ODD NUMBERED REGISTER NONE                               |

## Function:

These instructions do not exist in the native mode instruction set and are used only when operating in the 360/20 compatibility mode.

|       |                                                                                                                   | General        |                          | Possibl                                                                 | e Program Exceptions                                                                                 |
|-------|-------------------------------------------------------------------------------------------------------------------|----------------|--------------------------|-------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------|
| орсо  | DE                                                                                                                | FORMAT<br>TYPE | OBJECT<br>INST.<br>LGTH. | ☐ ADDRESSING ☐ DATA (INVALID SIGN/DIGIT)                                | ☐ PROTECTION ☐ SIGNIFICANCE                                                                          |
| MNEM. | HEX.                                                                                                              | 1,,,,          | (BYTES)                  | DECIMAL DIVIDE                                                          | SPECIFICATION:                                                                                       |
| ВС    | 47                                                                                                                | RX             | 4                        | DECIMAL OVERFLOW EXECUTE                                                | OP 1 NOT ON HALF-WORD BOUNDARY                                                                       |
|       | Conc                                                                                                              | dition Code    | s                        | EXPONENT OVERFLOW  EXPONENT UNDERFLOW                                   | OP 2 NOT ON HALF-WORD BOUNDARY OP 2 NOT ON FULL-WORD BOUNDARY                                        |
| IF RE | ☐ IF RESULT = 0, SET TO 0 ☐ IF RESULT < 0, SET TO 1 ☐ IF RESULT > 0, SET TO 2 ☐ IF OVERFLOW, SET TO 3 ■ UNCHANGED |                |                          | FIXED-POINT DIVIDE FIXED-POINT OVERFLOW FLOATING-POINT DIVIDE OPERATION | OP 2 NOT ON DOUBLE-WORD BOUNDARY OP 1 NOT EVEN NUMBERED REGISTER OP 1 NOT ODD NUMBERED REGISTER NONE |

### Function:

Checks the specified mask (m<sub>1</sub>), operand 1, with the current condition code. If any 1 bits match, a branch takes place to the location specified by operand 2; otherwise, the next sequential instruction is executed. See Table A—3 for the list of BC formats and equivalent extended mnemonic codes.

## **Explicit Format:**

| LABEL.   | $\Delta$ OPERATION $\Delta$ | OPERAND                                                          |
|----------|-----------------------------|------------------------------------------------------------------|
| [symbol] | ВС                          | m <sub>1</sub> ,d <sub>2</sub> (x <sub>2</sub> ,b <sub>2</sub> ) |
| !        |                             |                                                                  |

## Implicit Format:

|   | LABEL    | $\Delta$ OPERATION $\Delta$ | OPERAND                                          |
|---|----------|-----------------------------|--------------------------------------------------|
| _ | [symbol] | ВС                          | m <sub>1</sub> ,s <sub>2</sub> (x <sub>2</sub> ) |
|   |          |                             |                                                  |

- The mask, operand 1, determines the condition code setting in the PSW to be tested, as follows:
  - An 8 produces the mask 1000<sub>2</sub>, which tests bit 8 for a zero condition code.
  - A 4 produces the mask 0100<sub>2</sub>, which tests bit 9 for a 1 condition code.

## BC

- A 2 produces the mask 0010<sub>2</sub>, which tests bit 10 for a 2 condition code.
- A 1 produces the mask 0001<sub>2</sub>, which tests bit 11 for a 3 condition code.
- A zero produces the mask 0000<sub>2</sub>, which is equivalent to no-operation.
- Any combination of 1's and zeros in the mask tests for more than one condition code.
- Any 1 bit on and tested produces the branch.
- A mask specification of 15 (1111₂) produces an unconditional branch.

**BCR** 

|                                                                                                                   |      | General        |                          | Possible                                                                | Program Exceptions                                                                                   |
|-------------------------------------------------------------------------------------------------------------------|------|----------------|--------------------------|-------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------|
| орсо                                                                                                              | DE   | FORMAT<br>TYPE | OBJECT<br>INST.<br>LGTH. | ☐ ADDRESSING ☐ DATA (INVALID SIGN/DIGIT)                                | PROTECTION SIGNIFICANCE                                                                              |
| MNEM.                                                                                                             | HEX. | 1112           | (BYTES)                  | DECIMAL DIVIDE                                                          | SPECIFICATION:                                                                                       |
| BCR                                                                                                               | 07   | RR             | 2                        | DECIMAL OVERFLOW EXECUTE                                                | NOT A FLOATING-POINT REGISTER  OP 1 NOT ON HALF-WORD BOUNDARY                                        |
| Condition Codes                                                                                                   |      |                |                          | EXPONENT OVERFLOW  EXPONENT UNDERFLOW                                   | OP 2 NOT ON HALF-WORD BOUNDARY OP 2 NOT ON FULL-WORD BOUNDARY OP 2 NOT ON DOUBLE-WORD                |
| ☐ IF RESULT = 0, SET TO 0 ☐ IF RESULT < 0, SET TO 1 ☐ IF RESULT > 0, SET TO 2 ☐ IF OVERFLOW, SET TO 3 ☐ UNCHANGED |      |                |                          | FIXED-POINT DIVIDE FIXED-POINT OVERFLOW FLOATING-POINT DIVIDE OPERATION | OP 2 NOT ON DOUBLE-WORD BOUNDARY OP 1 NOT EVEN NUMBERED REGISTER OP 1 NOT ODD NUMBERED REGISTER NONE |

#### Function:

Checks the specified mask  $(m_1)$ , operand 1, with the current condition code. If any 1 bits match, a branch takes place to the location specified by operand 2  $(r_2)$ ; otherwise, the next sequential instruction is executed. If operand 2  $(r_2)$  is zero, no branch will take place. See Table A—3 for the list of BC formats and equivalent extended mnemonic codes.

## Implicit and Explicit Format:

| _ | LABEL    | $\Delta$ OPERATION $\Delta$ |                                | OPERAND |  |
|---|----------|-----------------------------|--------------------------------|---------|--|
|   | [symbol] | BCR                         | m <sub>1</sub> ,r <sub>2</sub> |         |  |
|   |          |                             |                                |         |  |

- The mask, operand 1, determines the condition code setting in the PSW to be tested, as follows:
  - An 8 produces the mask 1000<sub>2</sub>, which tests bit 8 for a zero condition code.
  - A 4 produces the mask 0100<sub>2</sub>, which tests bit 9 for a 1 condition code.
  - A 2 produces the mask 0010<sub>2</sub>, which tests bit 10 for a 2 condition code.
  - A 1 produces the mask 0001<sub>2</sub>, which tests bit 11 for a 3 condition code.
  - A zero produces the mask 0000<sub>2</sub>, which is equivalent to no-operation.
  - Any combination of 1's and zeros in the mask tests for more than one condition code.
  - Any 1 bit on and tested produces the branch.
- A mask specification of 15 (1111<sub>2</sub>) produces an unconditional branch.

PAGE

|       |                 | General                                                       |                          | Possible                                                                | e Program Exceptions                                                                                 |
|-------|-----------------|---------------------------------------------------------------|--------------------------|-------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------|
| ОРСС  | DE              | FORMAT<br>TYPE                                                | OBJECT<br>INST.<br>LGTH. | ☐ ADDRESSING ☐ DATA (INVALID SIGN/DIGIT)                                | ☐ PROTECTION ☐ SIGNIFICANCE                                                                          |
| MNEM. | HEX.            | ,                                                             | (BYTES)                  | DECIMAL DIVIDE                                                          | SPECIFICATION:                                                                                       |
| ВСТ   | 46              | RX                                                            | 4                        | DECIMAL OVERFLOW EXECUTE                                                | OP 1 NOT ON HALF-WORD BOUNDARY                                                                       |
|       | Condition Codes |                                                               |                          | EXPONENT OVERFLOW  EXPONENT UNDERFLOW                                   | OP 2 NOT ON HALF-WORD BOUNDARY OP 2 NOT ON FULL-WORD BOUNDARY OP 2 NOT ON DOUBLE-WORD                |
| IF RE | SULT<br>SULT    | = 0, SET TO<br>< 0, SET TO<br>> 0, SET TO<br>OW, SET TO<br>ED | ) 1<br>) 2               | FIXED POINT DIVIDE FIXED POINT OVERFLOW FLOATING POINT DIVIDE OPERATION | OP 2 NOT ON DOUBLE-WORD BOUNDARY OP 1 NOT EVEN NUMBERED REGISTER OP 1 NOT ODD NUMBERED REGISTER NONE |

### Function:

Each time this instruction is executed, the value in  $r_1$  is decremented by 1 and then tested to see whether the result is equal to zero. If the result is not equal to zero, a branch takes place to the location specified by operand 2. If the result is equal to zero, then no branch takes place and the next sequential instruction is executed. This instruction can be used to control the number of times a loop routine is executed. The initial value in  $r_1$  must be a positive value greater than zero.

## **Explicit Format:**

| LABEL    | $\Delta$ OPERATION $\Delta$ | OPERAND                                                          |
|----------|-----------------------------|------------------------------------------------------------------|
| [symbol] | ВСТ                         | r <sub>1</sub> ,d <sub>2</sub> (x <sub>2</sub> ,b <sub>2</sub> ) |

### Implicit Format:

| LABEL    | $\Delta$ OPERATION $\Delta$ | OPERAND                                          |
|----------|-----------------------------|--------------------------------------------------|
| [symbol] | вст                         | r <sub>1</sub> ,s <sub>2</sub> (x <sub>2</sub> ) |
|          |                             |                                                  |

**BCTR** 

|                                                                                                                   |      | General        |                          | Possible                                                                | e Program Exceptions                                                                                 |
|-------------------------------------------------------------------------------------------------------------------|------|----------------|--------------------------|-------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------|
| орсо                                                                                                              | DE   | FORMAT<br>TYPE | OBJECT<br>INST.<br>LGTH. | ☐ ADDRESSING ☐ DATA (INVALID SIGN/DIGIT)                                | ☐ PROTECTION ☐ SIGNIFICANCE                                                                          |
| MNEM.                                                                                                             | HEX. | '''            | (BYTES)                  | DECIMAL DIVIDE                                                          | SPECIFICATION:                                                                                       |
| BCTR                                                                                                              | 06   | RR             | 2                        | DECIMAL OVERFLOW EXECUTE                                                | OP 1 NOT ON HALF-WORD BOUNDARY                                                                       |
| Condition Codes                                                                                                   |      |                |                          | EXPONENT OVERFLOW  EXPONENT UNDERFLOW                                   | OP 2 NOT ON HALF-WORD BOUNDARY OP 2 NOT ON FULL-WORD BOUNDARY OP 2 NOT ON DOUBLE-WORD                |
| ☐ IF RESULT = 0, SET TO 0 ☐ IF RESULT < 0, SET TO 1 ☐ IF RESULT > 0, SET TO 2 ☐ IF OVERFLOW, SET TO 3 ☐ UNCHANGED |      |                |                          | FIXED-POINT DIVIDE FIXED-POINT OVERFLOW FLOATING-POINT DIVIDE OPERATION | OP 2 NOT ON DOUBLE-WORD BOUNDARY OP 1 NOT EVEN NUMBERED REGISTER OP 1 NOT ODD NUMBERED REGISTER NONE |

#### Function:

BCTR is the RR format type of BCT and works in the same way, except the second operand  $(r_2)$  is a register rather than a storage location. The BCTR instruction is initiated by loading a value in the first operand register  $(r_1)$  to be used as a count value and a branch address into the second operand register  $(r_2)$ . Each time this instruction is executed, the value in  $r_1$  is decremented by 1 and then tested to see whether the result is equal to zero. If the result is not equal to zero, a branch takes place to the address in the second operand  $(r_2)$ . If the result is equal to zero, then no branch takes place and the next sequential instruction is executed. This instruction can be used to control the number of times a loop routine is executed. The initial value in  $r_1$  must be a positive value greater than zero. If the second operand  $(r_2)$  is zero, no branch will take place.

### Implicit and Explicit Format:

| LABEL    | $\Delta$ OPERATION $\Delta$ | OPERAND                        |
|----------|-----------------------------|--------------------------------|
| [symbol] | BCTR                        | r <sub>1</sub> ,r <sub>2</sub> |

## BXH\*

|       |                                                                                                                   | General        |                          | Possible                                                                        | e Program Exceptions                                                                                 |
|-------|-------------------------------------------------------------------------------------------------------------------|----------------|--------------------------|---------------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------|
| орсо  | DĒ                                                                                                                | FORMAT<br>TYPE | OBJECT<br>INST.<br>LGTH. | ☐ ADDRESSING ☐ DATA (INVALID SIGN/DIGIT)                                        | PROTECTION SIGNIFICANCE                                                                              |
| MNEM. | HEX.                                                                                                              | , , , ,        | (BYTES)                  | DECIMAL DIVIDE                                                                  | SPECIFICATION:                                                                                       |
| вхн   | 86                                                                                                                | RS             | 4                        | DECIMAL OVERFLOW  EXECUTE                                                       | OP 1 NOT ON HALF-WORD BOUNDARY                                                                       |
|       | Conc                                                                                                              | lition Code    | S                        | EXPONENT OVERFLOW  EXPONENT UNDERFLOW                                           | OP 2 NOT ON HALF-WORD BOUNDARY OP 2 NOT ON FULL-WORD BOUNDARY OP 2 NOT ON DOUBLE-WORD                |
| IF RE | ☐ IF RESULT = 0, SET TO 0 ☐ IF RESULT < 0, SET TO 1 ☐ IF RESULT > 0, SET TO 2 ☐ IF OVERFLOW, SET TO 3 ■ UNCHANGED |                |                          | ☐ FIXED-POINT DIVIDE ☐ FIXED-POINT OVERFLOW ☐ FLOATING-POINT DIVIDE ■ OPERATION | OP 2 NOT ON DOUBLE-WORD BOUNDARY OP 1 NOT EVEN NUMBERED REGISTER OP 1 NOT ODD NUMBERED REGISTER NONE |

### Function:

Compares the algebraic sum of operand 1 ( $r_1$ ) and operand 2 ( $r_3$ ) to a value that is equal to the number of the register specified as operand 2 ( $r_3$ ) or  $r_3 + 1$ . If the sum of operand 1 ( $r_1$ ) and operand 2 ( $r_3$ ) is less than or equal to the compare value, the next sequential instruction is executed; if the sum is greater than the compare value, then a branch will take place to the location specified by operand 2, which is  $d_2$  ( $b_2$ ) or  $s_2$ . The value being used as the reference is always an odd-numbered register and is specified by  $r_3$  if  $r_3$  is an odd-numbered register, or is  $r_3 + 1$  if  $r_3$  is an even-numbered register. Following the comparison, the sum is placed in the first operand location. All quantities are treated as signed integers. An operation exception takes place if this operation is attempted on a processor that does not have this feature installed.

### **Explicit Format:**

| LABEL    | $\Delta$ OPERATION $\Delta$ | OPERAND                                                          |
|----------|-----------------------------|------------------------------------------------------------------|
| [symbol] | вхн                         | r <sub>1</sub> ,r <sub>3</sub> ,d <sub>2</sub> (b <sub>2</sub> ) |

### Implicit Format:

| LABEL    | $\Delta$ OPERATION $\Delta$ | OPERAND                                        |
|----------|-----------------------------|------------------------------------------------|
| [symbol] | вхн                         | r <sub>1</sub> ,r <sub>3</sub> ,s <sub>2</sub> |

<sup>\*</sup> BXH is a featured instruction. If you attempt to issue this instruction to a processor which does not have the control feature installed, you cause an operation program exception.

**BXLE\*** 

|                                                                                                                   |      | General        |                          | Possible                                                                | e Program Exceptions                                                                                 |  |
|-------------------------------------------------------------------------------------------------------------------|------|----------------|--------------------------|-------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------|--|
| OPCODE                                                                                                            |      | FORMAT<br>TYPE | OBJECT<br>INST.<br>LGTH. | <u>                                   </u>                              | PROTECTION SIGNIFICANCE                                                                              |  |
| MNEM.                                                                                                             | HEX. |                | (BYTES)                  | DECIMAL DIVIDE                                                          | SPECIFICATION:                                                                                       |  |
| BXLE                                                                                                              | 87   | RS             | 4                        | DECIMAL OVERFLOW EXECUTE                                                | OP 1 NOT ON HALF-WORD BOUNDARY                                                                       |  |
|                                                                                                                   | Cond | lition Code    | s                        | EXPONENT OVERFLOW  EXPONENT UNDERFLOW                                   | OP 2 NOT ON HALF-WORD BOUNDARY OP 2 NOT ON FULL-WORD BOUNDARY OP 2 NOT ON DOUBLE-WORD                |  |
| ☐ IF RESULT = 0, SET TO 0 ☐ IF RESULT < 0, SET TO 1 ☐ IF RESULT > 0, SET TO 2 ☐ IF OVERFLOW, SET TO 3 ☐ UNCHANGED |      |                |                          | FIXED-POINT DIVIDE FIXED-POINT OVERFLOW FLOATING-POINT DIVIDE OPERATION | OP 2 NOT ON DOUBLE-WORD BOUNDARY OP 1 NOT EVEN NUMBERED REGISTER OP 1 NOT ODD NUMBERED REGISTER NONE |  |

## Function:

This instruction is the same as BXH, except that the branch is made when the sum of the first operand  $(r_1)$  and the third operand  $(r_3)$  is less than or equal to the value being compared.

## **Explicit Format:**

| LABEL    | $\Delta$ OPERATION $\Delta$ | OPERAND                                                          |
|----------|-----------------------------|------------------------------------------------------------------|
| [symbol] | BXLE                        | r <sub>1</sub> ,r <sub>3</sub> ,d <sub>2</sub> (b <sub>2</sub> ) |

## Implicit Format:

| LABEL    | $\Delta$ OPERATION $\Delta$ | OPERAND                                        |
|----------|-----------------------------|------------------------------------------------|
| [symbol] | BXLE                        | r <sub>1</sub> ,r <sub>3</sub> ,s <sub>2</sub> |

<sup>\*</sup> BXLE is a featured instruction. If you attempt to issue this instruction to a processor which does not have the control feature installed, you cause an operation program exception.

|        |                                                                                                                                                         | General     |                          | Possible                                                                | e Program Exceptions                                                                                 |
|--------|---------------------------------------------------------------------------------------------------------------------------------------------------------|-------------|--------------------------|-------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------|
| ОРСО   | DE                                                                                                                                                      | FORMAT TYPE | OBJECT<br>INST.<br>LGTH. | ADDRESSING DATA (INVALID SIGN/DIGIT)                                    | PROTECTION SIGNIFICANCE                                                                              |
| MNEM.  | HEX.                                                                                                                                                    | ,,,_        | (BYTES)                  | DECIMAL DIVIDE                                                          | SPECIFICATION:                                                                                       |
| С      | 59                                                                                                                                                      | RX          | 4                        | DECIMAL OVERFLOW EXECUTE                                                | OP 1 NOT ON HALF-WORD BOUNDARY                                                                       |
|        | Condition Codes                                                                                                                                         |             |                          | EXPONENT OVERFLOW  EXPONENT UNDERFLOW                                   | OP 2 NOT ON HALF-WORD BOUNDARY OP 2 NOT ON FULL-WORD BOUNDARY OP 2 NOT ON DOUBLE-WORD                |
| ■ IF r | IF r <sub>1</sub> = OPERAND 2, SET TO 0 IF r <sub>1</sub> < OPERAND 2, SET TO 1 IF r <sub>1</sub> > OPERAND 2, SET TO 2 IF OVERFLOW, SET TO 3 UNCHANGED |             |                          | FIXED-POINT DIVIDE FIXED-POINT OVERFLOW FLOATING-POINT DIVIDE OPERATION | OP 2 NOT ON DOUBLE-WORD BOUNDARY OP 1 NOT EVEN NUMBERED REGISTER OP 1 NOT ODD NUMBERED REGISTER NONE |

## Function:

Causes the contents of operand 1  $(r_1)$  to be algebraically compared with the contents of operand 2, a full word in main storage.

## **Explicit Format:**

| LABEL    | $\Delta$ OPERATION $\Delta$ | OPERAND                                                          |
|----------|-----------------------------|------------------------------------------------------------------|
| [symbol] | С                           | r <sub>1</sub> ,d <sub>2</sub> (x <sub>2</sub> ,b <sub>2</sub> ) |
|          |                             |                                                                  |

## Implicit Format:

| LABEL    | $\Delta$ OPERATION $\Delta$ | OPERAND                                          |
|----------|-----------------------------|--------------------------------------------------|
| [symbol] | С                           | r <sub>1</sub> ,s <sub>2</sub> (x <sub>2</sub> ) |

- The contents of both operands remain unchanged.
- Operand 2 must be on a full-word boundary.

CD\*
Floating Point

|                                                                                                              | General         |                |                          | Possible Program Exceptions                                             |                                                                                                       |  |
|--------------------------------------------------------------------------------------------------------------|-----------------|----------------|--------------------------|-------------------------------------------------------------------------|-------------------------------------------------------------------------------------------------------|--|
| OPCODE                                                                                                       |                 | FORMAT<br>TYPE | OBJECT<br>INST.<br>LGTH. | ADDRESSING DATA (INVALID SIGN/DIGIT)                                    | PROTECTION SIGNIFICANCE                                                                               |  |
| MNEM.                                                                                                        | HEX.            |                | (BYTES)                  | DECIMAL DIVIDE                                                          | SPECIFICATION:                                                                                        |  |
| CD                                                                                                           | 69              | RX             | 4                        | DECIMAL OVERFLOW EXECUTE                                                | NOT A FLOATING-POINT REGISTER  OP 1 NOT ON HALF-WORD BOUNDARY                                         |  |
|                                                                                                              | Condition Codes |                |                          | EXPONENT OVERFLOW  EXPONENT UNDERFLOW                                   | OP 2 NOT ON HALF-WORD BOUNDARY OP 2 NOT ON FULL-WORD BOUNDARY                                         |  |
| IF OP1 = OP2, SET TO 0  IF OP1 < OP2, SET TO 1  IF OP1 > OP2, SET TO 2  ☐ IF OVERFLOW, SET TO 3  ☐ UNCHANGED |                 |                | !                        | FIXED-POINT DIVIDE FIXED-POINT OVERFLOW FLOATING-POINT DIVIDE OPERATION | OP 2 NOT ON DOUBLE-WORD BOUNDARY  OP 1 NOT EVEN NUMBERED REGISTER OP 1 NOT ODD NUMBERED REGISTER NONE |  |

#### Function:

8227 Rev. 2

**UP-NUMBER** 

Causes the contents of a double word in the register specified by operand 1  $(r_1)$  to be algebraically compared with the contents of a double word in storage specified by operand 2. The condition code is set by this instruction.

### **Explicit Format:**

| LABEL    | $\Delta$ operation $\Delta$ | OPERAND            |
|----------|-----------------------------|--------------------|
| [symbol] | CD                          | $r_1,d_2(x_2,b_2)$ |

## Implicit Format:

| LABEL    | $\Delta$ OPERATION $\Delta$ | OPERAND                                          |
|----------|-----------------------------|--------------------------------------------------|
| [symbol] | CD                          | r <sub>1</sub> ,s <sub>2</sub> (x <sub>2</sub> ) |

- Comparison is accomplished by the rules for normalized fixed-point subtraction. The operands are equal when the intermediate sum, including the guard digit, is zero.
- Operands with zero fractions compare as equal even when their signs or exponents are different.

<sup>\*</sup> CD is a featured instruction. If you attempt to issue this instruction to a processor which does not have the control feature installed, you cause an operation program exception.

PAGE

## CDR\*

## Floating Point

|                |                                                                                                                | General |                          | Possible                                                                | e Program Exceptions                                                                                 |
|----------------|----------------------------------------------------------------------------------------------------------------|---------|--------------------------|-------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------|
| орсо           | OPCODE FORMAT                                                                                                  |         | OBJECT<br>INST.<br>LGTH. | ADDRESSING DATA (INVALID SIGN/DIGIT)                                    | PROTECTION SIGNIFICANCE                                                                              |
| MNEM.          | HEX.                                                                                                           |         | (BYTES)                  | DECIMAL DIVIDE                                                          | SPECIFICATION:                                                                                       |
| CDR            | 29                                                                                                             | RR      | 2                        | DECIMAL OVERFLOW EXECUTE                                                | NOT A FLOATING-POINT REGISTER  OP 1 NOT ON HALF-WORD BOUNDARY                                        |
|                | Condition Codes                                                                                                |         |                          | EXPONENT OVERFLOW  EXPONENT UNDERFLOW                                   | OP 2 NOT ON HALF-WORD BOUNDARY OP 2 NOT ON FULL-WORD BOUNDARY                                        |
| IF OP<br>IF OP | ■ IF OP1 = OP2, SET TO 0 ■ IF OP1 < OP2, SET TO 1 ■ IF OP1 > OP2, SET TO 2 □ IF OVERFLOW, SET TO 3 □ UNCHANGED |         |                          | FIXED-POINT DIVIDE FIXED-POINT OVERFLOW FLOATING-POINT DIVIDE OPERATION | OP 2 NOT ON DOUBLE WORD BOUNDARY OP 1 NOT EVEN NUMBERED REGISTER OP 1 NOT ODD NUMBERED REGISTER NONE |

#### Function:

Causes the contents of a double word in the register specified by operand 1 ( $r_1$ ) to be algebraically compared with the contents of a double word in the register specified by operand 2 ( $r_2$ ). The condition code is set by this instruction.

## **Explicit and Implicit Format:**

| LABEL    | $\Delta$ OPERATION $\Delta$ |                                | OPERAND |  |
|----------|-----------------------------|--------------------------------|---------|--|
| [symbol] | CDR                         | r <sub>1</sub> ,r <sub>2</sub> |         |  |

- Comparison is accomplished by the rules for normalized fixed-point subtraction. The operands are equal when the intermediate sum, including the guard digit, is zero.
- Operands with zero fractions compare as equal even when their signs or exponents are different.

<sup>\*</sup> CDR is a featured instruction. If you attempt to issue this instruction to a processor which does not have the control feature installed, you cause an operation program exception.

CE\*

Floating Point

|                         |                                                                                                                | General   |                          | Possible                                                                | e Program Exceptions                                                                                 |
|-------------------------|----------------------------------------------------------------------------------------------------------------|-----------|--------------------------|-------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------|
| OPCO                    | OPCODE FORMAT                                                                                                  |           | OBJECT<br>INST.<br>LGTH. | ADDRESSING DATA (INVALID SIGN/DIGIT)                                    | PROTECTION SIGNIFICANCE                                                                              |
| MNEM.                   | HEX.                                                                                                           | , , , , , | (BYTES)                  | DECIMAL DIVIDE                                                          | SPECIFICATION:                                                                                       |
| CE                      | 79                                                                                                             | RX        | 4                        | DECIMAL OVERFLOW EXECUTE                                                | NOT A FLOATING-POINT REGISTER  OP 1 NOT ON HALF-WORD BOUNDARY                                        |
|                         | Condition Codes                                                                                                |           |                          | EXPONENT OVERFLOW  EXPONENT UNDERFLOW                                   | OP 2 NOT ON HALF-WORD BOUNDARY OP 2 NOT ON FULL-WORD BOUNDARY OP 2 NOT ON DOUBLE-WORD                |
| IF OP<br>IF OP<br>IF OV | ■ IF OP1 = OP2, SET TO 0 ■ IF OP1 < OP2, SET TO 1 ■ IF OP1 > OP2, SET TO 2 □ IF OVERFLOW, SET TO 3 □ UNCHANGED |           |                          | FIXED-POINT DIVIDE FIXED-POINT OVERFLOW FLOATING-POINT DIVIDE OPERATION | OP 2 NOT ON DOUBLE-WORD BOUNDARY OP 1 NOT EVEN NUMBERED REGISTER OP 1 NOT ODD NUMBERED REGISTER NONE |

## Function:

Causes the contents of a full word in the register specified by operand 1 ( $r_1$ ) to be algebraically compared with the contents of a full word word in storage specified by operand 2. The condition code is set by this instruction.

## **Explicit Format:**

| LABEL    | $\Delta$ OPERATION $\Delta$ | OPERAND                                                          |
|----------|-----------------------------|------------------------------------------------------------------|
| [symbol] | CE                          | r <sub>1</sub> ,d <sub>2</sub> (x <sub>2</sub> ,b <sub>2</sub> ) |
| [symbol] | CE                          | r <sub>1</sub> ,d <sub>2</sub> (x <sub>2</sub> ,b <sub>2</sub> ) |

## Implicit Format:

| LABEL    | $\Delta$ operation $\Delta$ | OPERAND                                          |
|----------|-----------------------------|--------------------------------------------------|
| [symbol] | CE                          | r <sub>1</sub> ,s <sub>2</sub> (x <sub>2</sub> ) |

- Comparison is accomplished by the rules for normalized fixed-point subtraction. The operands are equal when the intermediate sum, including the guard digit, is zero.
- Operands with zero fractions compare as equal even when their signs or exponents are different.

CE is a featured instruction. If you attempt to issue this instruction to a processor which does not have the control feature installed, you cause an operation program exception.

## **CER\***

## Floating Point

|                                        | General                                                                                                        |                |                                                           | Possible Program Exceptions                                             |                                                                                       |  |
|----------------------------------------|----------------------------------------------------------------------------------------------------------------|----------------|-----------------------------------------------------------|-------------------------------------------------------------------------|---------------------------------------------------------------------------------------|--|
| OPCODE FORMAT INST. TYPE LGTH. (BYTES) |                                                                                                                | INST.<br>LGTH. | ☐ ADDRESSING ☐ DATA (INVALID SIGN/DIGIT) ☐ DECIMAL DIVIDE | ☐ PROTECTION ☐ SIGNIFICANCE ■ SPECIFICATION:                            |                                                                                       |  |
| CER                                    | 39                                                                                                             | RR             | 2                                                         | DECIMAL OVERFLOW EXECUTE                                                | NOT A FLOATING-POINT REGISTER  OP 1 NOT ON HALF-WORD BOUNDARY                         |  |
|                                        | Condition Codes                                                                                                |                | S                                                         | EXPONENT OVERFLOW  EXPONENT UNDERFLOW  FIXED-POINT DIVIDE               | OP 2 NOT ON HALF-WORD BOUNDARY OP 2 NOT ON FULL-WORD BOUNDARY OP 2 NOT ON DOUBLE-WORD |  |
| IF OP<br>IF OP                         | ■ IF OP1 = OP2, SET TO 0 ■ IF OP1 < OP2, SET TO 1 ■ IF OP1 > OP2, SET TO 2 □ IF OVERFLOW, SET TO 3 □ UNCHANGED |                |                                                           | FIXED-POINT DIVIDE FIXED-POINT OVERFLOW FLOATING-POINT DIVIDE OPERATION | BOUNDARY  OP 1 NOT EVEN NUMBERED REGISTER  OP 1 NOT ODD NUMBERED REGISTER  NONE       |  |

### Function:

Causes the full-word contents of the register specified by operand 1 ( $r_1$ ) to be algebraically compared with the contents of a full word in the register specified by operand 2 ( $r_2$ ). The condition code is set by this instruction.

## **Explicit and Implicit Format:**

| LABEL    | $\Delta$ OPERATION $\Delta$ | OPERAND                        |
|----------|-----------------------------|--------------------------------|
| [symbol] | CER                         | r <sub>1</sub> ,r <sub>2</sub> |

- Comparison is accomplished by the rules for normalized fixed-point subtraction. The operands are equal when the intermediate sum, including the guard digit, is zero.
- Operands with zero fractions compare as equal even when their signs or exponents are different.

<sup>\*</sup> CER is a featured instruction. If you attempt to issue this instruction to a processor which does not have the control feature installed, you cause an operation program exception.

СН

PAGE

|                                                                                                                                                         | General         |                |                          | Possible                                                                   | e Program Exceptions                                                                                 |
|---------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------|----------------|--------------------------|----------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------|
| OPCODE                                                                                                                                                  |                 | FORMAT<br>TYPE | OBJECT<br>INST.<br>LGTH. | ADDRESSING DATA (INVALID SIGN/DIGIT)                                       | PROTECTION SIGNIFICANCE                                                                              |
| MNEM.                                                                                                                                                   | HEX.            |                | (BYTES)                  | DECIMAL DIVIDE                                                             | SPECIFICATION:                                                                                       |
| СН                                                                                                                                                      | 49              | RX             | 4                        | ☐ DECIMAL OVERFLOW ☐ EXECUTE                                               | OP 1 NOT ON HALF-WORD BOUNDARY                                                                       |
|                                                                                                                                                         | Condition Codes |                | s                        | EXPONENT OVERFLOW  EXPONENT UNDERFLOW                                      | OP 2 NOT ON HALF-WORD BOUNDARY OP 2 NOT ON FULL-WORD BOUNDARY                                        |
| IF r <sub>1</sub> = OPERAND 2, SET TO 0 IF r <sub>1</sub> < OPERAND 2, SET TO 1 IF r <sub>1</sub> > OPERAND 2, SET TO 2 IF OVERFLOW, SET TO 3 UNCHANGED |                 |                | T TO 1<br>T TO 2         | FIXED-POINT DIVIDE  FIXED-POINT OVERFLOW  FLOATING-POINT DIVIDE  OPERATION | OP 2 NOT ON DOUBLE-WORD BOUNDARY OP 1 NOT EVEN NUMBERED REGISTER OP 1 NOT ODD NUMBERED REGISTER NONE |

## Function:

Causes the contents of operand 1  $(r_1)$  to be algebraically compared with the contents of operand 2 (a half word in main storage), after operand 2 is expanded, by propagating the sign bit to fill a full word.

### **Explicit Format:**

| LABEL    | $\Delta$ OPERATION $\Delta$ | OPERAND                                                          |  |  |
|----------|-----------------------------|------------------------------------------------------------------|--|--|
| [symbol] | СН                          | r <sub>1</sub> ,d <sub>2</sub> (x <sub>2</sub> ,b <sub>2</sub> ) |  |  |

## Implicit Format:

| LABEL    | $\Delta$ OPERATION $\Delta$ | OPERAND                                          |
|----------|-----------------------------|--------------------------------------------------|
| [symbol] | СН                          | r <sub>1</sub> ,s <sub>2</sub> (x <sub>2</sub> ) |

- The contents of both operands remain unchanged.
- Operand 2 must be on a half-word boundary.

PAGE

|                                                                                                                                                         | General         |       |                                                     | Possible Program Exceptions                                             |                                                                                                      |  |
|---------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------|-------|-----------------------------------------------------|-------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------|--|
| OPCODE FORMAT INST. TYPE LGTH. (BYTES)                                                                                                                  |                 | INST. | ADDRESSING DATA (INVALID SIGN/DIGIT) DECIMAL DIVIDE | PROTECTION SIGNIFICANCE SPECIFICATION:                                  |                                                                                                      |  |
| CL                                                                                                                                                      | 55              | RX    | 4                                                   | DECIMAL OVERFLOW                                                        | □ NOT A FLOATING-POINT REGISTER □ OP 1 NOT ON HALF-WORD BOUNDARY                                     |  |
|                                                                                                                                                         | Condition Codes |       |                                                     | EXPONENT OVERFLOW  EXPONENT UNDERFLOW                                   | OP 2 NOT ON HALF-WORD BOUNDARY OP 2 NOT ON FULL-WORD BOUNDARY OP 2 NOT ON DOUBLE-WORD                |  |
| IF r <sub>1</sub> = OPERAND 2, SET TO 0 IF r <sub>1</sub> < OPERAND 2, SET TO 1 IF r <sub>1</sub> > OPERAND 2, SET TO 2 IF OVERFLOW, SET TO 3 UNCHANGED |                 |       | T TO 1                                              | FIXED-POINT DIVIDE FIXED-POINT OVERFLOW FLOATING-POINT DIVIDE OPERATION | OP 2 NOT ON DOUBLE-WORD BOUNDARY OP 1 NOT EVEN NUMBERED REGISTER OP 1 NOT ODD NUMBERED REGISTER NONE |  |

### Function:

Causes the contents of a full word in storage specified by operand 2 to be compared with the contents of the register specified by operand 1  $(r_1)$ . The condition code is set according to the comparison result.

## **Explicit Format:**

| LABEL    | $\Delta$ OPERATION $\Delta$ | OPERAND                                                          |  |  |  |
|----------|-----------------------------|------------------------------------------------------------------|--|--|--|
| [symbol] | CL                          | r <sub>1</sub> ,d <sub>2</sub> (x <sub>2</sub> ,b <sub>2</sub> ) |  |  |  |

## Implicit Format:

| LABEL    | $\Delta$ OPERATION $\Delta$ | OPERAND                                          |  |  |
|----------|-----------------------------|--------------------------------------------------|--|--|
| [symbol] | CL                          | r <sub>1</sub> ,s <sub>2</sub> (x <sub>2</sub> ) |  |  |

- Operands are considered unsigned binary numbers and all bit combinations are valid.
- The contents of both operands remain unchanged.
- Operand 2 must be on a full-word boundary.

PAGE

| General                                                                                                        |    |                |                          | Possible Program Exceptions                                             |                                                                                                      |  |
|----------------------------------------------------------------------------------------------------------------|----|----------------|--------------------------|-------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------|--|
|                                                                                                                |    | FORMAT<br>TYPE | OBJECT<br>INST.<br>LGTH. | ADDRESSING DATA (INVALID SIGN/DIGIT)                                    | PROTECTION SIGNIFICANCE                                                                              |  |
|                                                                                                                |    | 1              | (BYTES)                  | DECIMAL DIVIDE                                                          | SPECIFICATION:                                                                                       |  |
| CLC                                                                                                            | D5 | SS             | 6                        | DECIMAL OVERFLOW EXECUTE                                                | OP 1 NOT ON HALF-WORD BOUNDARY                                                                       |  |
| Condition Codes                                                                                                |    |                | s                        | EXPONENT OVERFLOW  EXPONENT UNDERFLOW                                   | OP 2 NOT ON HALF-WORD BOUNDARY OP 2 NOT ON FULL-WORD BOUNDARY OP 2 NOT ON DOUBLE-WORD                |  |
| ■ IF OP1 = OP2, SET TO 0 ■ IF OP1 < OP2, SET TO 1 ■ IF OP1 > OP2, SET TO 2 □ IF OVERFLOW, SET TO 3 □ UNCHANGED |    |                |                          | FIXED-POINT DIVIDE FIXED-POINT OVERFLOW FLOATING-POINT DIVIDE OPERATION | OP 2 NOT ON DOUBLE-WORD BOUNDARY OP 1 NOT EVEN NUMBERED REGISTER OP 1 NOT ODD NUMBERED REGISTER NONE |  |

## Function:

Causes the contents of one area in main storage specified by operand 1 to be compared with an equal length area in main storage specified by operand 2. The condition code is set according to the comparison result.

## **Explicit Format:**

| LABEL    | $\Delta$ OPERATION $\Delta$ | OPERAND                                                             |  |  |  |
|----------|-----------------------------|---------------------------------------------------------------------|--|--|--|
| [symbol] | CLC                         | d <sub>1</sub> (I,b <sub>1</sub> ),d <sub>2</sub> (b <sub>2</sub> ) |  |  |  |
|          |                             |                                                                     |  |  |  |

#### Implicit Format:

| LABEL    | $\Delta$ OPERATION $\Delta$ | OPERAND                           |  |  |
|----------|-----------------------------|-----------------------------------|--|--|
| [symbol] | CLC                         | s <sub>1</sub> (I),s <sub>2</sub> |  |  |

- The I specification of operand 1 specifies the length of both operands.
- Operands are considered unsigned binary numbers and all bit combinations are valid.
- The contents of both operands remain unchanged.
- The instruction is processed from left to right, byte by byte.
- If the number of bytes to be compared is not explicitly shown in operand 1, then the number will be equal to the length attribute of operand 1.

## **CLI**

|                |                                                                                                                                                            | General        |                          | Possible Program Exceptions                                             |                                                                                                      |  |
|----------------|------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------|--------------------------|-------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------|--|
| OPCODE         |                                                                                                                                                            | FORMAT<br>TYPE | OBJECT<br>INST.<br>LGTH. | ADDRESSING DATA (INVALID SIGN/DIGIT)                                    | PROTECTION SIGNIFICANCE                                                                              |  |
| MNEM.          | HEX.                                                                                                                                                       | 1112           | (BYTES)                  | DECIMAL DIVIDE                                                          | SPECIFICATION:                                                                                       |  |
| CLI            | 95                                                                                                                                                         | SI             | 4                        | DECIMAL OVERFLOW EXECUTE                                                | OP 1 NOT ON HALF-WORD BOUNDARY                                                                       |  |
|                | Condition Codes                                                                                                                                            |                | s                        | EXPONENT OVERFLOW  EXPONENT UNDERFLOW                                   | OP 2 NOT ON HALF-WORD BOUNDARY OP 2 NOT ON FULL-WORD BOUNDARY                                        |  |
| IF OP<br>IF OP | IF OPERAND 1 = i <sub>2</sub> , SET TO 0 IF OPERAND 1 < i <sub>2</sub> , SET TO 1 IF OPERAND 1 > i <sub>2</sub> , SET TO 2 IF OVERFLOW, SET TO 3 UNCHANGED |                |                          | FIXED-POINT DIVIDE FIXED-POINT OVERFLOW FLOATING-POINT DIVIDE OPERATION | OP 2 NOT ON DOUBLE-WORD BOUNDARY OP 1 NOT EVEN NUMBERED REGISTER OP 1 NOT ODD NUMBERED REGISTER NONE |  |

### Function:

Causes the contents of one byte in main storage specified by operand 1 to be compared with the one byte of immediate data specified in operand 2. The condition code is set according to the comparison result.

## **Explicit Format:**

| LABEL    | $\Delta$ OPERATION $\Delta$ | OPERAND                                         |  |
|----------|-----------------------------|-------------------------------------------------|--|
| [symbol] | CLI                         | d <sub>1</sub> (b <sub>1</sub> ),i <sub>2</sub> |  |

## Implicit Format:

| LABEL    | $\Delta$ operation $\Delta$ | OPERAND                         |
|----------|-----------------------------|---------------------------------|
| [symbol] | CLI                         | \$ <sub>1</sub> ,i <sub>2</sub> |

- Operands are considered unsigned binary numbers and all bit combinations are valid.
- Operands are one byte in length.
- The contents of operand 1 remain unchanged.

**CLR** 

PAGE

|                                                       |                                              | General        |                          | Possible                                                                | e Program Exceptions                                                                                 |
|-------------------------------------------------------|----------------------------------------------|----------------|--------------------------|-------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------|
| OPCO                                                  | DE                                           | FORMAT<br>TYPE | OBJECT<br>INST.<br>LGTH. | ☐ ADDRESSING ☐ DATA (INVALID SIGN/DIGIT)                                | ☐ PROTECTION ☐ SIGNIFICANCE                                                                          |
| MNEM.                                                 | HEX.                                         |                | (BYTES)                  | DECIMAL DIVIDE                                                          | SPECIFICATION:                                                                                       |
| CLR                                                   | 15                                           | RR             | 2                        | DECIMAL OVERFLOW EXECUTE                                                | OP 1 NOT ON HALF-WORD BOUNDARY                                                                       |
| Condition Codes                                       |                                              |                | s                        | EXPONENT OVERFLOW  EXPONENT UNDERFLOW                                   | OP 2 NOT ON HALF-WORD BOUNDARY OP 2 NOT ON FULL-WORD BOUNDARY OP 2 NOT ON DOUBLE-WORD                |
| ■ IF r <sub>1</sub><br>■ IF r <sub>1</sub><br>□ IF OV | F r <sub>1</sub> = r <sub>2</sub> , SET TO 0 |                |                          | FIXED-POINT DIVIDE FIXED-POINT OVERFLOW FLOATING-POINT DIVIDE OPERATION | OP 2 NOT ON DOUBLE-WORD BOUNDARY OP 1 NOT EVEN NUMBERED REGISTER OP 1 NOT ODD NUMBERED REGISTER NONE |

## Function:

Causes the contents of the operand 1  $(r_1)$  register to be compared with the contents of the operand 2  $(r_2)$  register. The condition code is set according to the comparison result.

Explicit and Implicit Format:

| LABEL    | $\Delta$ OPERATION $\Delta$ | OPERAND                        |
|----------|-----------------------------|--------------------------------|
| [symbol] | CLR                         | r <sub>1</sub> ,r <sub>2</sub> |

- Operands are considered unsigned binary numbers and all bit combinations are valid.
- The contents of both operands remain unchanged.

CP

|       |                          | General                                                       |                          | Possible                                                                | e Program Exceptions                                                                                 |
|-------|--------------------------|---------------------------------------------------------------|--------------------------|-------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------|
| орсо  | DE                       | FORMAT<br>TYPE                                                | OBJECT<br>INST.<br>LGTH. | ADDRESSING DATA (INVALID SIGN/DIGIT)                                    | PROTECTION SIGNIFICANCE                                                                              |
| MNEM. | нех.                     | 1,,,_                                                         | (BYTES)                  | DECIMAL DIVIDE                                                          | SPECIFICATION:                                                                                       |
| CP    | F9                       | SS                                                            | 6                        | DECIMAL OVERFLOW EXECUTE                                                | OP 1 NOT ON HALF-WORD BOUNDARY                                                                       |
|       | Conc                     | lition Code                                                   | S                        | EXPONENT OVERFLOW  EXPONENT UNDERFLOW                                   | OP 2 NOT ON HALF-WORD BOUNDARY OP 2 NOT ON FULL-WORD BOUNDARY OP 2 NOT ON DOUBLE-WORD                |
| IF OP | 1 < OP<br>1 > OP<br>ERFL | 2, SET TO 0<br>2, SET TO 1<br>2, SET TO 2<br>OW, SET TO<br>ED | !                        | FIXED-POINT DIVIDE FIXED-POINT OVERFLOW FLOATING-POINT DIVIDE OPERATION | OP 2 NOT ON DOUBLE-WORD BOUNDARY OP 1 NOT EVEN NUMBERED REGISTER OP 1 NOT ODD NUMBERED REGISTER NONE |

#### Function:

Compares the contents of two storage areas to see whether they are algebraically equal, operand 1 is higher, or operand 1 is lower. The condition code is set to reflect the results of this compare. A branch instruction is usually used after the compare instruction.

## **Explicit Format:**

| LABEL    | $\Delta$ operation $\Delta$ | OPERAND                                                                                           |
|----------|-----------------------------|---------------------------------------------------------------------------------------------------|
| [symbol] | СР                          | d <sub>1</sub> (l <sub>1</sub> ,b <sub>1</sub> ),d <sub>2</sub> (l <sub>2</sub> ,b <sub>2</sub> ) |

## Implicit Format:

| LABEL    | $\Delta$ OPERATION $\Delta$ | <u> </u>                                                          | OPERAND |
|----------|-----------------------------|-------------------------------------------------------------------|---------|
| [symbol] | СР                          | s <sub>1</sub> (I <sub>1</sub> ),s <sub>2</sub> (I <sub>2</sub> ) |         |

- All signs and digits are checked for validity, and comparison proceeds from right to left.
- If the operand fields are unequal in length, the shorter field is extended with zero digits.
- Operands with zero values and unlike signs compare as equal.
- All valid codes representing the same sign are considered equal.
- Operand 1 and operand 2 may overlap if their least significant bytes coincide.
- The contents of both operands remain unchanged.

**CR** 

PAGE

|                         |                                                                                                                   | General        |                          | Possible                                                                | e Program Exceptions                                                                                 |  |
|-------------------------|-------------------------------------------------------------------------------------------------------------------|----------------|--------------------------|-------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------|--|
| OPCODE                  |                                                                                                                   | FORMAT<br>TYPE | OBJECT<br>INST.<br>LGTH. | ☐ ADDRESSING ☐ DATA (INVALID SIGN/DIGIT)                                | PROTECTION SIGNIFICANCE                                                                              |  |
| MNEM.                   | HEX.                                                                                                              | 111.0          | (BYTES)                  | DECIMAL DIVIDE                                                          | SPECIFICATION:                                                                                       |  |
| CR                      | 19                                                                                                                | RR             | 2                        | DECIMAL OVERFLOW  EXECUTE                                               | □ NOT A FLOATING-POINT REGISTER □ OP 1 NOT ON HALF-WORD BOUNDARY                                     |  |
| Condition Codes         |                                                                                                                   |                | 5                        | EXPONENT OVERFLOW  EXPONENT UNDERFLOW                                   | OP 2 NOT ON HALF-WORD BOUNDARY OP 2 NOT ON FULL-WORD BOUNDARY                                        |  |
| IF rq<br>IF rq<br>IF O\ | IF $r_1 = r_2$ , SET TO 0  IF $r_1 < r_2$ , SET TO 1  IF $r_1 > r_2$ , SET TO 2  IF OVERFLOW, SET TO 3  UNCHANGED |                |                          | FIXED-POINT DIVIDE FIXED-POINT OVERFLOW FLOATING-POINT DIVIDE OPERATION | OP 2 NOT ON DOUBLE-WORD BOUNDARY OP 1 NOT EVEN NUMBERED REGISTER OP 1 NOT ODD NUMBERED REGISTER NONE |  |

Function:

Causes the contents of operand 1  $(r_1)$  to be algebraically compared to operand 2  $(r_2)$ .

**Explicit and Implicit Format:** 

| RATION △                       | OPERAND |
|--------------------------------|---------|
| r <sub>1</sub> ,r <sub>2</sub> |         |
|                                |         |

## Operational Consideration:

■ The contents of both registers remain unchanged.

|       |              | General                                                       |                          | Possible                                                                | e Program Exceptions                                                                                 |
|-------|--------------|---------------------------------------------------------------|--------------------------|-------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------|
| орсо  | DE           | FORMAT<br>TYPE                                                | OBJECT<br>INST.<br>LGTH. | ADDRESSING DATA (INVALID SIGN/DIGIT)                                    | PROTECTION SIGNIFICANCE                                                                              |
| MNEM. | HEX.         |                                                               | (BYTES)                  | DECIMAL DIVIDE                                                          | SPECIFICATION:                                                                                       |
| CVB   | 4F           | RX                                                            | 4                        | DECIMAL OVERFLOW EXECUTE                                                | OP 1 NOT ON HALF-WORD BOUNDARY                                                                       |
|       | Conc         | lition Code                                                   | S                        | EXPONENT OVERFLOW  EXPONENT UNDERFLOW                                   | OP 2 NOT ON HALF-WORD BOUNDARY OP 2 NOT ON FULL-WORD BOUNDARY OR 2 NOT ON DOUBLE WORD                |
| IF RE | SULT<br>SULT | = 0, SET TO<br>< 0, SET TO<br>> 0, SET TO<br>OW, SET TO<br>ED | ) 1<br>) 2               | FIXED-POINT DIVIDE FIXED-POINT OVERFLOW FLOATING-POINT DIVIDE OPERATION | OP 2 NOT ON DOUBLE-WORD BOUNDARY OP 1 NOT EVEN NUMBERED REGISTER OP 1 NOT ODD NUMBERED REGISTER NONE |

## Function:

Converts the packed decimal number in operand 2, a double word in main storage, to a fixed-point signed binary number, which is placed in operand 1 ( $r_1$ ).

## **Explicit Format:**

| LABEL    | $\Delta$ OPERATION $\Delta$ | OPERAND                                                          |
|----------|-----------------------------|------------------------------------------------------------------|
| [symbol] | CVB                         | r <sub>1</sub> ,d <sub>2</sub> (x <sub>2</sub> ,b <sub>2</sub> ) |

## Implicit Format:

| LABEL    | $\Delta$ OPERATION $\Delta$ | OPERAND                                          |  |
|----------|-----------------------------|--------------------------------------------------|--|
| [symbol] | СVВ                         | r <sub>1</sub> ,s <sub>2</sub> (x <sub>2</sub> ) |  |

- Operand 2 is a 15-digit and sign packed decimal number in a double word on a double-word boundary in main storage.
- Operand 2 is checked for valid digits and sign code before conversion to a fixed-point, 32-bit signed binary number.

**CVB** 

- The maximum number that can be converted and still contained in a 32-bit register is 2,147,483,647 (2³¹—1). The minimum number is —2,147,483,648 (—2³¹). For decimal numbers exceeding this range, the 32 least significant bits are stored in the first operand location and a fixed-point divide exception is generated.
- If operand 2 is negative, the result will be in twos complement notation.
- The contents of operand 2 remain unchanged.

|                                                                                                                   |                 | General        | -                        | Possible                                                                | e Program Exceptions                                                                                 |
|-------------------------------------------------------------------------------------------------------------------|-----------------|----------------|--------------------------|-------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------|
| OPCODE                                                                                                            |                 | FORMAT<br>TYPE | OBJECT<br>INST.<br>LGTH. | ADDRESSING DATA (INVALID SIGN/DIGIT)                                    | PROTECTION SIGNIFICANCE                                                                              |
| MNEM.                                                                                                             | HEX.            | ,,,,           | (BYTES)                  | DECIMAL DIVIDE                                                          | SPECIFICATION:                                                                                       |
| CVD                                                                                                               | 4E              | RX             | 4                        | DECIMAL OVERFLOW EXECUTE                                                | OP 1 NOT ON HALF WORD BOUNDARY                                                                       |
|                                                                                                                   | Condition Codes |                |                          | EXPONENT OVERFLOW  EXPONENT UNDERFLOW                                   | OP 2 NOT ON HALF-WORD BOUNDARY OP 2 NOT ON FULL-WORD BOUNDARY                                        |
| ☐ IF RESULT = 0, SET TO 0 ☐ IF RESULT < 0, SET TO 1 ☐ IF RESULT > 0, SET TO 2 ☐ IF OVERFLOW, SET TO 3 ☐ UNCHANGED |                 |                | ) 1<br>) 2               | FIXED-POINT DIVIDE FIXED-POINT OVERFLOW FLOATING-POINT DIVIDE OPERATION | OP 2 NOT ON DOUBLE-WORD BOUNDARY OP 1 NOT EVEN NUMBERED REGISTER OP 1 NOT ODD NUMBERED REGISTER NONE |

#### Function:

Converts the fixed-point signed binary number in operand 1  $(r_1)$  to a packed decimal number, which is placed in operand 2, a double word in main storage.

## **Explicit Format:**

| LABEL    | $\Delta$ OPERATION $\Delta$ | OPERAND                                                          |
|----------|-----------------------------|------------------------------------------------------------------|
| [symbol] | CVD                         | r <sub>1</sub> ,d <sub>2</sub> (x <sub>2</sub> ,b <sub>2</sub> ) |

### Implicit Format:

| LABEL    | $\Delta$ operation $\Delta$ | OPERAND                                          |
|----------|-----------------------------|--------------------------------------------------|
| [symbol] | CVD                         | r <sub>1</sub> ,s <sub>2</sub> (x <sub>2</sub> ) |

- Operand 1 is a fixed-point, 32-bit signed binary number in a register.
- Operand 2 is a 15-digit packed signed decimal number in a double-word main storage location on a double-word boundary.
- The contents of operand 1 remain unchanged.

D

#### Function:

Causes the value in the even-odd pair of registers specified by operand 1 (r<sub>1</sub>) to be divided by the full-word operand 2 (the divisor). The quotient and remainder are placed in the operand 1 registers.

## **Explicit Format:**

| LABEL    | $\Delta$ OPERATION $\Delta$ | OPERAND                                                          |
|----------|-----------------------------|------------------------------------------------------------------|
| [symbol] | D                           | r <sub>1</sub> ,d <sub>2</sub> (x <sub>2</sub> ,b <sub>2</sub> ) |

#### Implicit Format:

| LABEL    | $\Delta$ OPERATION $\Delta$ | OPERAND                                          |
|----------|-----------------------------|--------------------------------------------------|
| [symbol] | D                           | r <sub>1</sub> ,s <sub>2</sub> (x <sub>2</sub> ) |

- Operand 1 is treated as a 64-bit fixed-point signed binary integer and occupies an even-odd register pair. The operand 1 field of the instruction must specify an even-numbered register. The 32-bit remainder and 32-bit quotient replace the dividend in the even-numbered and odd-numbered register, respectively.
- Operand 2 is treated as a 32-bit fixed-point signed binary integer. The contents of operand 2 remain unchanged after execution.
- The sign of the quotient is determined algebraically, and the remainder assumes the sign of the dividend. A zero quotient or zero remainder is always positive.
- When the quotient exceeds 32 bits or the divisor is equal to zero, a fixed-point divide exception occurs, no division takes place, and the dividend remains unchanged.

## Floating Point

| General                                                                                               |                 |                |                          | Possible Program Exceptions                                                                                       |                                                                                                                                                               |  |
|-------------------------------------------------------------------------------------------------------|-----------------|----------------|--------------------------|-------------------------------------------------------------------------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------|--|
| OPCODE                                                                                                |                 | FORMAT<br>TYPE | OBJECT<br>INST.<br>LGTH. | ADDRESSING DATA (INVALID SIGN/DIGIT)                                                                              | PROTECTION SIGNIFICANCE                                                                                                                                       |  |
| MNEM.                                                                                                 | HEX.            |                | (BYTES)                  | DECIMAL DIVIDE                                                                                                    | SPECIFICATION:                                                                                                                                                |  |
| DD                                                                                                    | 6D              | RX             | 4                        | ☐ EXECUTE                                                                                                         | NOT A FLOATING-POINT REGISTER OP 1 NOT ON HALF-WORD BOUNDARY                                                                                                  |  |
|                                                                                                       | Condition Codes |                |                          | EXPONENT OVERFLOW  EXPONENT UNDERFLOW  FIXED-POINT DIVIDE  FIXED-POINT OVERFLOW  FLOATING-POINT DIVIDE  OPERATION | OP 2 NOT ON HALF-WORD BOUNDARY OP 2 NOT ON FULL-WORD BOUNDARY OP 2 NOT ON DOUBLE-WORD BOUNDARY OP 1 NOT EVEN NUMBERED REGISTER OP 1 NOT ODD NUMBERED REGISTER |  |
| ☐ IF RESULT = 0, SET TO 0 ☐ IF RESULT < 0, SET TO 1 ☐ IF RESULT > 0, SET TO 2 ☐ IF OVERFLOW, SET TO 3 |                 |                | ) 1<br>) 2               |                                                                                                                   |                                                                                                                                                               |  |
| UNCHANGED                                                                                             |                 |                |                          |                                                                                                                   | NONE                                                                                                                                                          |  |

## Function:

Causes the double-word contents of the operand 1  $(r_1)$  register to be divided by the contents of the double word in storage specified by operand 2. The normalized quotient is placed in the register specified by operand 1  $(r_1)$ . Any remainder is not preserved.

## **Explicit Format:**

| LABEL    | $\Delta$ OPERATION $\Delta$ | OPERAND                                                          |
|----------|-----------------------------|------------------------------------------------------------------|
| [symbol] | DD                          | r <sub>1</sub> ,d <sub>2</sub> (x <sub>2</sub> ,b <sub>2</sub> ) |

## Implicit Format:

| LABEL    | $\Delta$ OPERATION $\Delta$ | OPERAND                                          |
|----------|-----------------------------|--------------------------------------------------|
| [symbol] | DD                          | r <sub>1</sub> ,s <sub>2</sub> (x <sub>2</sub> ) |
|          |                             |                                                  |

<sup>\*</sup> DD is a featured instruction. If you attempt to issue this instruction to a processor which does not have the control feature installed, you cause an operation program exception.

DDR\*

PAGE

Floating Point

| General                                                                                                     |      |                |                          | Possible Program Exceptions                                             |                                                                                                      |  |
|-------------------------------------------------------------------------------------------------------------|------|----------------|--------------------------|-------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------|--|
| OPCODE                                                                                                      |      | FORMAT<br>TYPE | OBJECT<br>INST.<br>LGTH. | ☐ ADDRESSING ☐ DATA (INVALID SIGN/DIGIT)                                | PROTECTION SIGNIFICANCE                                                                              |  |
| MNEM.                                                                                                       | HEX. | –              | (BYTES)                  | DECIMAL DIVIDE                                                          | SPECIFICATION:                                                                                       |  |
| DDR                                                                                                         | 2D   | RR             | 2                        | DECIMAL OVERFLOW EXECUTE                                                | NOT A FLOATING-POINT REGISTER  OP 1 NOT ON HALF-WORD BOUNDARY                                        |  |
|                                                                                                             | Cond | dition Code    | s                        | EXPONENT OVERFLOW  EXPONENT UNDERFLOW                                   | OP 2 NOT ON HALF-WORD BOUNDARY OP 2 NOT ON FULL-WORD BOUNDARY OP 2 NOT ON DOUBLE-WORD                |  |
| if RESULT = 0, SET TO 0  IF RESULT < 0, SET TO 1  IF RESULT > 0, SET TO 2  IF OVERFLOW, SET TO 3  UNCHANGED |      |                |                          | FIXED-POINT DIVIDE FIXED-POINT OVERFLOW FLOATING-POINT DIVIDE OPERATION | OP 2 NOT ON DOUBLE-WORD BOUNDARY OP 1 NOT EVEN NUMBERED REGISTER OP 1 NOT ODD NUMBERED REGISTER NONE |  |

#### Function:

Causes the double-word contents of the operand 1  $(r_1)$  register to be divided by the double-word contents of the operand 2  $(r_2)$  register. The normalized quotient is placed in the operand 1  $(r_1)$  register. Any remainder is not preserved.

## **Explicit and Implicit Format:**

| LABEL    | $\Delta$ operation $\Delta$ | OPERAND                        |
|----------|-----------------------------|--------------------------------|
| [symbol] | DDR                         | r <sub>1</sub> ,r <sub>2</sub> |

<sup>\*</sup> DDR is a featured instruction. If you attempt to issue this instruction to a processor which does not have the control feature installed, you cause an operation program exception.

## DE\*

#### Floating Point

| General                                                                                                           |      |                |                          | Possible Program Exceptions                                             |                                                                                                      |  |
|-------------------------------------------------------------------------------------------------------------------|------|----------------|--------------------------|-------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------|--|
| OPCODE                                                                                                            |      | FORMAT<br>TYPE | OBJECT<br>INST.<br>LGTH. | ADDRESSING DATA (INVALID SIGN/DIGIT)                                    |                                                                                                      |  |
| MNEM.                                                                                                             | HEX. |                | (BYTES)                  | DECIMAL DIVIDE                                                          | SPECIFICATION:                                                                                       |  |
| DE                                                                                                                | 7D   | RX             | 4                        | DECIMAL OVERFLOW EXECUTE                                                | NOT A FLOATING POINT REGISTER  OP 1 NOT ON HALF WORD BOUNDARY                                        |  |
|                                                                                                                   | Conc | lition Code    | s                        | EXPONENT OVERFLOW  EXPONENT UNDERFLOW                                   | OP 2 NOT ON HALF-WORD BOUNDARY OP 2 NOT ON FULL-WORD BOUNDARY                                        |  |
| ☐ IF RESULT = 0, SET TO 0 ☐ IF RESULT < 0, SET TO 1 ☐ IF RESULT > 0, SET TO 2 ☐ IF OVERFLOW, SET TO 3 ☐ UNCHANGED |      |                |                          | FIXED-POINT DIVIDE FIXED-POINT OVERFLOW FLOATING-POINT DIVIDE OPERATION | OP 2 NOT ON DOUBLE-WORD BOUNDARY OP 1 NOT EVEN NUMBERED REGISTER OP 1 NOT ODD NUMBERED REGISTER NONE |  |

#### Function:

Causes the full-word contents of the operand 1 (r<sub>1</sub>) register to be divided by the full-word contents of a full word in storage specified by operand 2. The normalized quotient is placed in a full word in the operand 1 (r<sub>1</sub>) register. Any remainder is not preserved.

#### **Explicit Format:**

| LABEL    | $\Delta$ OPERATION $\Delta$ | OPERAND                                                          |
|----------|-----------------------------|------------------------------------------------------------------|
| [symbol] | DE                          | r <sub>1</sub> ,d <sub>2</sub> (x <sub>2</sub> ,b <sub>2</sub> ) |
|          |                             | <b>1</b> .                                                       |

## Implicit Format:

| LABEL    | $\Delta$ OPERATION $\Delta$ | OPERAND                                          |
|----------|-----------------------------|--------------------------------------------------|
| [symbol] | DE                          | r <sub>1</sub> ,s <sub>2</sub> (x <sub>2</sub> ) |

DE is a featured instruction. If you attempt to issue this instruction to a processor which does not have the control feature installed, you cause an operation program exception.

PAGE

DER\*
Floating Point

|                                                                                                                   |      | General        |                          | Possible                                                                   | Program Exceptions                                                                                   |
|-------------------------------------------------------------------------------------------------------------------|------|----------------|--------------------------|----------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------|
| OPCODE                                                                                                            |      | FORMAT<br>TYPE | OBJECT<br>INST.<br>LGTH. | ☐ ADDRESSING ☐ DATA (INVALID SIGN/DIGIT)                                   | PROTECTION SIGNIFICANCE                                                                              |
| MNEM.                                                                                                             | HEX. | ,,,,           | (BYTES)                  | DECIMAL DIVIDE                                                             | SPECIFICATION:                                                                                       |
| DER                                                                                                               | 3D   | RR             | 2                        | DECIMAL OVERFLOW EXECUTE                                                   | NOT A FLOATING-POINT REGISTER  OP 1 NOT ON HALF-WORD BOUNDARY                                        |
| Condition Codes                                                                                                   |      |                | S                        | EXPONENT OVERFLOW  EXPONENT UNDERFLOW                                      | OP 2 NOT ON HALF-WORD BOUNDARY OP 2 NOT ON FULL-WORD BOUNDARY OP 2 NOT ON DOUBLE-WORD                |
| ☐ IF RESULT = 0, SET TO 0 ☐ IF RESULT < 0, SET TO 1 ☐ IF RESULT > 0, SET TO 2 ☐ IF OVERFLOW, SET TO 3 ■ UNCHANGED |      |                | 0 1                      | FIXED-POINT DIVIDE  FIXED-POINT OVERFLOW  FLOATING-POINT DIVIDE  OPERATION | OP 2 NOT ON DOUBLE-WORD BOUNDARY OP 1 NOT EVEN NUMBERED REGISTER OP 1 NOT ODD NUMBERED REGISTER NONE |

#### Function:

Causes the full-word contents of the operand 1  $(r_1)$  register to be divided by the full-word contents of the operand 2  $(r_2)$  register. The normalized quotient is placed in a full word in the operand 1  $(r_1)$  register. Any remainder is not preserved.

#### **Explicit and Implicit Format:**

| LABEL    | $\Delta$ operation $\Delta$ |                                | OPERAND |   |
|----------|-----------------------------|--------------------------------|---------|---|
| [symbol] | DER                         | r <sub>1</sub> ,r <sub>2</sub> |         | • |

<sup>\*</sup> DER is a featured instruction. If you attempt to issue this instruction to a processor which does not have the control feature installed, you cause an operation program exception.

# **DIAG**

|       |                      | General                                                       | ·                        | Possible                                                                | e Program Exceptions                                                                                 |
|-------|----------------------|---------------------------------------------------------------|--------------------------|-------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------|
| ОРСО  | DE                   | FORMAT<br>TYPE                                                | OBJECT<br>INST.<br>LGTH. | ☐ ADDRESSING ☐ DATA (INVALID SIGN/DIGIT)                                | PROTECTION SIGNIFICANCE                                                                              |
| MNEM. | HEX.                 | ,,,_                                                          | (BYTES)                  | DECIMAL DIVIDE                                                          | SPECIFICATION:                                                                                       |
| DIAG  | 83                   | SI                                                            | 4                        | DECIMAL OVERFLOW EXECUTE                                                | OP 1 NOT ON HALF-WORD BOUNDARY                                                                       |
|       | Condition Codes      |                                                               |                          | EXPONENT OVERFLOW  EXPONENT UNDERFLOW                                   | OP 2 NOT ON HALF-WORD BOUNDARY OP 2 NOT ON FULL-WORD BOUNDARY OP 2 NOT ON DOUBLE-WORD                |
| IF RE | SULT<br>SULT<br>ERFL | = 0, SET TO<br>< 0, SET TO<br>> 0, SET TO<br>OW, SET TO<br>ED | ) 1<br>) 2               | FIXED-POINT DIVIDE FIXED-POINT OVERFLOW FLOATING-POINT DIVIDE OPERATION | OP 2 NOT ON DOUBLE-WORD BOUNDARY OP 1 NOT EVEN NUMBERED REGISTER OP 1 NOT ODD NUMBERED REGISTER NONE |

Function:

Resets the processor to zero after control storage is loaded and provides various diagnostic and supervisor operations.

## **Explicit Format:**

| LABEL    | $\Delta$ OPERATION $\Delta$ | OPERAND                                          |
|----------|-----------------------------|--------------------------------------------------|
| [symbol] | DIAG                        | d <sub>1</sub> (b <sub>1</sub> ), i <sub>2</sub> |

## Implicit Format:

| LABEL    | $\Delta$ OPERATION $\Delta$ | OPERAND                         |
|----------|-----------------------------|---------------------------------|
| [symbol] | DIAG                        | s <sub>1</sub> , i <sub>2</sub> |

DP

|                                                                                                                   |                 | General        |                          | Possible                                                                | e Program Exceptions                                                                                 |
|-------------------------------------------------------------------------------------------------------------------|-----------------|----------------|--------------------------|-------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------|
| OPCODE                                                                                                            |                 | FORMAT<br>TYPE | OBJECT<br>INST.<br>LGTH. | ■ ADDRESSING ■ DATA (INVALID SIGN/DIGIT)                                | PROTECTION SIGNIFICANCE                                                                              |
| MNEM.                                                                                                             | HEX.            | , , , ,        | (BYTES)                  | DECIMAL DIVIDE                                                          | SPECIFICATION:                                                                                       |
| DP                                                                                                                | FD              | SS             | 6                        | DECIMAL OVERFLOW  EXECUTE                                               | OP 1 NOT ON HALF-WORD BOUNDARY                                                                       |
|                                                                                                                   | Condition Codes |                |                          | EXPONENT OVERFLOW  EXPONENT UNDERFLOW                                   | OP 2 NOT ON HALF-WORD BOUNDARY OP 2 NOT ON FULL-WORD BOUNDARY                                        |
| ☐ IF RESULT = 0, SET TO 0 ☐ IF RESULT < 0, SET TO 1 ☐ IF RESULT > 0, SET TO 2 ☐ IF OVERFLOW, SET TO 3 ☐ UNCHANGED |                 |                | ) 1<br>) 2               | FIXED-POINT DIVIDE FIXED-POINT OVERFLOW FLOATING-POINT DIVIDE OPERATION | OP 2 NOT ON DOUBLE-WORD BOUNDARY OP 1 NOT EVEN NUMBERED REGISTER OP 1 NOT ODD NUMBERED REGISTER NONE |

#### Function:

Causes the contents of operand 1 (the dividend) to be divided by the contents of operand 2 (the divisor). The quotient and remainder are placed in the operand 1 location.

#### **Explicit Format:**

| LABEL    | $\Delta$ OPERATION $\Delta$ | OPERAND                                                                                           |
|----------|-----------------------------|---------------------------------------------------------------------------------------------------|
| [symbol] | DP                          | d <sub>1</sub> (I <sub>1</sub> ,b <sub>1</sub> ),d <sub>2</sub> (I <sub>2</sub> ,b <sub>2</sub> ) |
|          |                             |                                                                                                   |

#### Implicit Format:

| LABEL    | $\Delta$ OPERATION $\Delta$ | OPERAND                                                           |
|----------|-----------------------------|-------------------------------------------------------------------|
| [symbol] | DP ·                        | s <sub>1</sub> (I <sub>1</sub> ),s <sub>2</sub> (I <sub>2</sub> ) |

- All signs and digits are checked for validity.
- The quotient and remainder occupy the entire operand 1 field. The remainder is right-justified in the field, carries the sign of operand 1, and is equal in size to operand 2. The quotient, carrying the algebraically determined sign, is right-justified in the rest of the field.
- The maximum dividend (operand 1) size is 31 digits and sign. The maximum quotient size is 29 digits and sign. The smallest remainder is one digit and sign. The maximum divisor is 15 digits.

| • |  |  |
|---|--|--|
|   |  |  |
|   |  |  |
|   |  |  |
|   |  |  |
|   |  |  |
|   |  |  |
|   |  |  |
|   |  |  |
|   |  |  |
|   |  |  |
|   |  |  |

DP

- Operand 1 and operand 2 fields may overlap if their least significant bytes coincide.
- If the number of quotient digits exceeds the size of the quotient field or if division by zero is attempted, a decimal divide exception results; the divisor and dividend remain unchanged in their storage locations.
- A decimal divide exception occurs if the dividend does not have at least one leading zero. The condition for a decimal divide exception can be determined by aligning the leftmost digit of the divisor (operand 2) field with the leftmost less 1 digit of the dividend (operand 1) field and performing a subtraction. If, after alignment, the divisor is less than or equal to the dividend, a decimal divide exception is indicated.
- A specification exception indicates the divisor exceeds 15 digits or operand 1 is not longer than operand 2.

PAGE

| General                                                                                                           |      |              |         | Possible                                                                | e Program Exceptions                                                                                  |  |
|-------------------------------------------------------------------------------------------------------------------|------|--------------|---------|-------------------------------------------------------------------------|-------------------------------------------------------------------------------------------------------|--|
| OPCODE                                                                                                            |      | FORMAT INST. |         | ☐ ADDRESSING ☐ DATA (INVALID SIGN/DIGIT)                                | PROTECTION SIGNIFICANCE                                                                               |  |
| MNEM.                                                                                                             | HEX. | ,,,,_        | (BYTES) | DECIMAL DIVIDE                                                          | SPECIFICATION:                                                                                        |  |
| DR                                                                                                                | 1D   | RR           | 2       | DECIMAL OVERFLOW EXECUTE                                                | OP 1 NOT ON HALF-WORD BOUNDARY                                                                        |  |
|                                                                                                                   | Cond | dition Code  | s       | EXPONENT OVERFLOW  EXPONENT UNDERFLOW                                   | OP 2 NOT ON HALF-WORD BOUNDARY  OP 2 NOT ON FULL-WORD BOUNDARY  OP 2 NOT ON DOUBLE-WORD               |  |
| ☐ IF RESULT = 0, SET TO 0 ☐ IF RESULT < 0, SET TO 1 ☐ IF RESULT > 0, SET TO 2 ☐ IF OVERFLOW, SET TO 3 ☐ UNCHANGED |      |              |         | FIXED-POINT DIVIDE FIXED-POINT OVERFLOW FLOATING-POINT DIVIDE OPERATION | OP 2 NOT ON DOUBLE-WORD BOUNDARY  OP 1 NOT EVEN NUMBERED REGISTER OP 1 NOT ODD NUMBERED REGISTER NONE |  |

#### Function:

Causes the value in the even-odd registers specified by operand 1  $(r_1)$  to be divided by the value in the register (the divisor) specified by operand 2  $(r_2)$ . The quotient and remainder are placed in the operand 1 registers.

### **Explicit and Implicit Format:**

| LABEL    | $\Delta$ OPERATION $\Delta$ | OPERAND                        |
|----------|-----------------------------|--------------------------------|
| [symbol] | DR                          | r <sub>1</sub> ,r <sub>2</sub> |

- Operand 1 is treated as a 64-bit fixed-point signed binary integer and occupies an even-odd register pair. The operand 1 field of the instruction must specify an even-numbered register. The 32-bit remainder and 32-bit quotient replace the dividend in the even-numbered and odd-numbered register, respectively.
- Operand 2 is treated as a 32-bit fixed-point signed binary integer. The contents of operand 2 remain unchanged after execution.
- The sign of the quotient is determined algebraically and the remainder assumes the sign of the dividend. A zero quotient or zero remainder is always positive.
- When the quotient exceeds 32 bits or the divisor is equal to zero, a fixed-point divide exception occurs, no division takes place, and the dividend remains unchanged.
- A specification exception will occur if r<sub>1</sub> specifies an odd-numbered register.

<sup>\*</sup> DR is a featured instruction. If you attempt to issue this instruction to a processor which does not have the control feature installed, you cause an operation program exception.

|        |                      | General                 |         | Possible                                                                | e Program Exceptions                                                                                 |  |
|--------|----------------------|-------------------------|---------|-------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------|--|
| OPCODE |                      | FORMAT INST. TYPE LGTH. |         | ADDRESSING DATA (INVALID SIGN/DIGIT)                                    | PROTECTION SIGNIFICANCE                                                                              |  |
| MNEM.  | HEX.                 |                         | (BYTES) | DECIMAL DIVIDE                                                          | SPECIFICATION:                                                                                       |  |
| ED     | DE                   | SS                      | 6       | DECIMAL OVERFLOW  EXECUTE                                               | OP 1 NOT ON HALF-WORD BOUNDARY                                                                       |  |
|        | Cond                 | dition Code             | s       | EXPONENT OVERFLOW  EXPONENT UNDERFLOW                                   | OP 2 NOT ON HALF-WORD BOUNDARY OP 2 NOT ON FULL-WORD BOUNDARY                                        |  |
|        | TO 1<br>TO 2<br>TO 3 | NSIDERATI               | ONS     | FIXED-POINT DIVIDE FIXED-POINT OVERFLOW FLOATING-POINT DIVIDE OPERATION | OP 2 NOT ON DOUBLE-WORD BOUNDARY OP 1 NOT EVEN NUMBERED REGISTER OP 1 NOT ODD NUMBERED REGISTER NONE |  |

#### Function:

Causes the packed data specified by operand 2 to be unpacked and edited under the control of a mask (pattern) specified by operand 1. The result is placed in the main storage location specified by operand 1. This instruction can produce the following types of results:

■ Zero suppression

Ex: 00173 — 173

Character protection

Ex: 000453 — \*\*\*4.53

Punctuation

Ex: 123400 — \$1,234.00

■ Multiple field editing

Ex: 12531468 — 12.53△△14.68

#### **Explicit Format:**

| LABEL    | $\Delta$ OPERATION $\Delta$ | OPERAND                                                             |
|----------|-----------------------------|---------------------------------------------------------------------|
| [symbol] | ED                          | d <sub>1</sub> (I,b <sub>1</sub> ),d <sub>2</sub> (b <sub>2</sub> ) |

#### Implicit Format:

| LABEL    | $\Delta$ OPERATION $\Delta$ | OPERAND                           |
|----------|-----------------------------|-----------------------------------|
| [symbol] | ED                          | s <sub>1</sub> (I),s <sub>2</sub> |

- For every digit in the source field, operand 2, there must be an equal number of digit select characters, significance start characters, or a combination of both in the pattern.
- The significance indicator, referred to as the S switch, indicates by its on or off state the significance or nonsignificance, respectively, of subsequent operand 2 digits or message characters. Significant operand 2 digits replace their corresponding digit select or significance start characters in the result. Significant message characters remain unchanged in the result.
- The S switch is turned off when the *edit* instruction starts and when a sign code of "C" (+) is reached; and it is turned on when the first signficant (nonzero) digit is reached.
- When the S switch is off, zeros to be transferred from operand 2 are suppressed and the fill character is inserted in the corresponding operand 1 position. When the S switch is on, any zero to be transferred from operand 2 is unpacked into the corresponding operand 1 position. At the beginning of execution, the S switch is off.
- Editing includes sign and punctuation control and the suppression and protection of leading zeros. It also facilitates programmed blanking for all zero fields. Several fields may be edited in one operation, and numeric information may be combined with text.
- The instruction proceeds from left to right.
- Operand 2 data must be in packed format and must contain valid numerics and sign codes.
- The original contents of operand 1 is the mask, the pattern which controls the edit process. Depending on the edit requirements, some or most of the bytes originally in operand 1 are replaced by data from operand 2. The mask is expressed in unpacked format and may consist of any combination of 8-bit characters.
- As the mask is scanned from left to right, one of three things happens to each mask character:
  - An operand 2 digit is expanded to a zoned character. The zoned character replaces the mask character. When the operand 2 digit is stored as the result, its code is expanded from packed to unpacked format by attaching a generated zone code.
  - The mask character is left unchanged.
  - A fill character is stored in the result. The fill character is taken from the first byte position of the mask. The choice of this character is not dependent upon the editing function initiated by this code. The editing function occurs after the code has been assigned as a fill character.

ED

Each mask character is replaced by a result character that depends on three conditions:

- the digit obtained from operand 2;
- the mask character; and
- the S switch status.

When a digit select or significance start byte is found in the mask, the S switch and an operand 2 digit are examined. This results in either the unpacked operand 2 digit or the fill character replacing the mask character. A valid decimal digit (if the mask byte is a significance start) or nonzero decimal digit (if the mask byte is a digit select) sets the S switch to on if the operand 2 byte does not contain a plus code in the four least significant bit positions.

- The fill character is the leftmost character of the edit mask (operand 1). Any valid hexadecimal value (B.2) may be used as a fill character. This character is retained for the editing which follows. This position does not receive a digit from the operand 2 data.
- The digit select byte is a character in the operand 1 mask represented by EBCDIC code 20. If the digit select byte is encountered and the S switch is on, any digit, 0 through 9, is unpacked to replace the digit select byte. If the S switch is off, the operand 2 digit is examined and only nonzero digits are unpacked into operand 1. The fill character replaces the digit select byte if the examined digit is zero. The S switch is turned on when the first nonzero operand 2 digit is encountered; this allows succeeding zeros from operand 2 to be included in the result.
- The significance start byte is represented in the edit mask by EBCDIC code 21. The significance start byte performs the same function as the digit select byte except the significance start byte turns the S switch on, regardless of the value of the current operand 2 digit. Once the S switch is on, it remains on for all succeeding digits; however, the current digit is not affected. The S switch may be turned off by a field separator byte or by a positive sign code within operand 2.
- Any other symbol or data in the operand 1 edit mask, as represented by hexadecimal codes, is retained unchanged if the S switch is on. If the S switch is off, this other data is replaced by the fill character. During this operation, the digit of operand 2 is neither accessed nor addressed-advanced.
- The sign of operand 2, positive or negative, must be a value greater than binary 9 (1002<sub>2</sub>). Any hexadecimal value A through F is acceptable. The sign itself is not moved to operand 1; instead, a sign indicator, such as a minus sign or letters CR, is either deleted from or retained in operand 1, depending on the sign of operand 2.

The sign of operand 2 also affects the S switch. A positive sign turns the S switch off, thus causing the following characters in operand 1 to be replaced by the fill character. A negative sign leaves the S switch unchanged.

- If the fill character is a blank, if no significance start byte appears in the mask, and if operand 2 is all zeros, the editing operation blanks the result field.
- Overlapping operand 1 and operand 2 fields produces unpredictable results.
- The length specification (I) in the object instruction specifies the length of the mask (operand 1). The length of the mask can be determined as:
  - one byte for the fill character;
  - one byte for each digit select byte, significance start byte, and field separator byte; and
  - one byte for each message character.

Usually, operand 2 is shorter than operand 1 because a zone (a half byte) and a numeric (a full byte) are inserted in the result for each operand 2 digit. The total number of digit-select and significance start bytes in the mask must equal the number of operand 2 digits to be edited.

- If operand 2 containing unpacked data is to be edited, it must first be packed by the PACK instruction. In packing an odd number of bytes, an odd number of digit positions and the sign are produced. In packing an even number of bytes, an odd number of digit positions and the sign are produced. The extra digit position in the latter case is zero and is the most significant position in operand 2. The extra position must be provided for in the mask by specifying an extra DSB or SSB. Space, asterisk, or other character fill occurs and may be dropped when transferring the edited operand to output.
- Multiple-field editing operations are indicated by the presence of one or more field separator bytes (EBCDIC code 22). The field separator byte identifies the individual fields in this operation and is always replaced in the mask with a fill character. The S switch is always off after the field separator byte is encountered. If field separators are not indicated by the mask, the entire operand 2 is considered one field.
- The condition code, reflecting the status of the last source field edited, is set:
  - to zero when all of the operand 2 digits in the last field are zero; if the mask of the last field has
    no significance start or digit select bytes, the operand 2 digits are not examined and the
    condition code is set to zero;
  - to 1 when a nonzero operand 2 digit is detected and the S switch is set after the last mask digit is examined; or
  - to 2 when a nonzero operand 2 digit is detected and the S switch is off after the last mask digit is examined.

Code 3 is not used.

ED

The operation of the edit instruction is summarized in the following table.

| Mask (Operand 1)<br>Character | EBCDIC<br>Code           | S Switch<br>Status | Data (Operand 2)<br>Character | Resulting<br>(Operand 1)<br>Character | Resulting<br>S Switch<br>Status |
|-------------------------------|--------------------------|--------------------|-------------------------------|---------------------------------------|---------------------------------|
| Fill character                | Any                      | Off                | Not examined                  | None                                  | Off                             |
| Digit select                  | 20                       | On                 | Digit                         | Digit                                 | On*                             |
| byte                          |                          | Off                | Nonzero                       | Digit                                 | On*                             |
|                               |                          | Off                | Zero                          | Fill<br>character                     | Off                             |
| Significance                  | 21                       | On                 | Digit                         | Digit                                 | On*                             |
| start byte                    |                          | Off                | Nonzero                       | Digit                                 | On*                             |
|                               |                          | Off                | Zero                          | Fill<br>character                     | On*                             |
| Message<br>character          | Any except<br>20, 21, 22 | On                 | Not examined                  | Message<br>character                  | On*                             |
|                               |                          | Off                | Not examined                  | Fill<br>character                     | Off                             |
| Field<br>separator byte       | 22                       | On                 | Not examined                  | Fill<br>character                     | Off                             |
|                               |                          | Off                | Not examined                  | Fill character                        | Off                             |

<sup>\*</sup>Sign detection (examined simultaneously with operand 2 digit) affects the S switch as follows:

- 1. A plus or minus sign detected as a most significant digit causes a data exception.
- 2. A plus sign detected as a least significant digit causes the S switch to be turned off.
- 3. A minus sign has no effect on the S switch.
- If the number of bytes to be edited is not explicitly shown in operand 1, then the number will be equal to the length attribute of operand 1.

## **EDMK\***

|         |                              | General        |                                     | Possible                                                                                                     | e Program Exceptions                                                                                                                                               |
|---------|------------------------------|----------------|-------------------------------------|--------------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| OPCO    |                              | FORMAT<br>TYPE | OBJECT<br>INST.<br>LGTH.<br>(BYTES) | ADDRESSING DATA (INVALID SIGN/DIGIT) DECIMAL DIVIDE                                                          | PROTECTION SIGNIFICANCE SPECIFICATION:                                                                                                                             |
| EDMK    | DF                           | SS             | 6                                   | DECIMAL OVERFLOW                                                                                             | OP 1 NOT ON HALF-WORD BOUNDARY                                                                                                                                     |
| SET SET | TO 0<br>TO 1<br>TO 2<br>TO 3 | dition Code    |                                     | EXPONENT OVERFLOW EXPONENT UNDERFLOW FIXED-POINT DIVIDE FIXED-POINT OVERFLOW FLOATING-POINT DIVIDE OPERATION | OP 2 NOT ON HALF-WORD BOUNDARY OP 2 NOT ON FULL-WORD BOUNDARY OP 2 NOT ON DOUBLE-WORD BOUNDARY OP 1 NOT EVEN NUMBERED REGISTER OP 1 NOT ODD NUMBERED REGISTER NONE |

#### Function:

This instruction is identical to the *edit* (ED) instruction, except for the additional function of placing the address of the first significant result digit in register 1. This is done to permit the use of a floating \$ character or other character in the result field.

### **Explicit Format:**

| LABEL    | $\Delta$ OPERATION $\Delta$ | OPERAND                                                             |  |  |  |
|----------|-----------------------------|---------------------------------------------------------------------|--|--|--|
| [symbol] | EDMK                        | d <sub>1</sub> (I,b <sub>1</sub> ),d <sub>2</sub> (b <sub>2</sub> ) |  |  |  |

#### Implicit Format:

| LABEL    | $\Delta$ OPERATION $\Delta$ |                                   | OPERAND |
|----------|-----------------------------|-----------------------------------|---------|
| [symbol] | EDMK                        | s <sub>1</sub> (i),s <sub>2</sub> |         |

- The edit and mark (EDMK) instruction is identical to the edit (ED) instruction, except that EDMK inserts the resulting address of the first significant character in the low-order 24 bits of general register 1. This insertion occurs whenever the result character is a zoned source digit and the significant switch is zero before examination of the digit.
- The condition code is set in the same manner as the *edit* instruction.

<sup>\*</sup> EDMK is a featured instruction. If you attempt to issue this instruction to a processor which does not have the control feature installed, you cause an operation program exception.

**EDMK** 

- The edit and mark instruction facilitates the programming of floating currency-symbol insertion. The character address inserted in general register 1 is one more than the address where a floating currency sign would be inserted. The branch on count (BCTR) instruction, with zero in the R2 field, may be used to reduce the inserted address by 1.
- The character address is not stored when significance is forced. To ensure that general register 1 contains a valid address when significance is forced, it is necessary to place into the register beforehand the address of the pattern character that immediately follows the significance starter.
- When a single instruction is used to edit several fields, the address of the first significant result character of each field is inserted into bit positions 8 through 31 of general register 1. Only the address of the first significant character of the last field is available after the instruction is completed.
- If the number of bytes to be edited is not explicitly shown in operand 1, then the number will be equal to the length attribute of operand 1.

|    | General                                                                                                                          |      |                |                          | Possible                                                                | e Program Exceptions                                                                                 |
|----|----------------------------------------------------------------------------------------------------------------------------------|------|----------------|--------------------------|-------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------|
|    | орсо                                                                                                                             | DE   | FORMAT<br>TYPE | OBJECT<br>INST.<br>LGTH. | ■ ADDRESSING □ DATA (INVALID SIGN/DIGIT)                                | PROTECTION SIGNIFICANCE                                                                              |
| T. | MNEM.                                                                                                                            | HEX. | 1716           | (BYTES)                  | DECIMAL DIVIDE                                                          | SPECIFICATION:                                                                                       |
|    | EX                                                                                                                               | 44   | RX             | 4                        | DECIMAL OVERFLOW                                                        | OP 1 NOT ON HALF-WORD BOUNDARY                                                                       |
| Ī  | Condition Codes                                                                                                                  |      |                |                          | EXPONENT OVERFLOW  EXPONENT UNDERFLOW                                   | OP 2 NOT ON HALF-WORD BOUNDARY OP 2 NOT ON FULL-WORD BOUNDARY OP 2 NOT ON DOUBLE-WORD                |
|    | ☐ IF RESULT = 0, SET TO 0 ☐ IF RESULT < 0, SET TO 1 ☐ IF RESULT > 0, SET TO 2 ☐ IF OVERFLOW, SET TO 3 ■ SEE OPER. CONSIDERATIONS |      |                | 0 1<br>0 2<br>0 3        | FIXED-POINT DIVIDE FIXED-POINT OVERFLOW FLOATING-POINT DIVIDE OPERATION | OP 2 NOT ON DOUBLE-WORD BOUNDARY OP 1 NOT EVEN NUMBERED REGISTER OP 1 NOT ODD NUMBERED REGISTER NONE |

#### Function:

Used to branch to a nonsequential instruction, then to execute it, with or without modification, and then to return to the normal sequence of instructions.

If operand 1 is 0, the instruction at the operand 2 address, specified by  $d_2$  ( $x_2$ ,  $b_2$ ), is executed without modification. If operand 1 ( $r_1$ ) is in the range 1—15, the contents of  $r_1$  are used to modify the subject instruction when that instruction is staticized.

When  $r_1$  is nonzero, modification of the operand 2 instruction proceeds as follows: A logical addition (OR) is performed on the contents of bits 24 through 31 of  $r_1$  and bits 8 through 15 of the operand 2 instruction. The result replaces bits 8 through 15 of the operand 2 instruction. The rules of operation for logical addition are illustrated by the following truth table:

| Operand 1 | Operand 2 | Result |
|-----------|-----------|--------|
| .0        | 0         | 0      |
| 0         | 1         | 1      |
| 1         | 0         | 1      |
| 1         | 1         | 1      |
|           |           |        |

The subject instruction is executed as if it were in the normal instruction sequence except that the instruction length code and updated instruction address fields of the current program status word (PSW) reflect the *execute* instruction. The subject instruction itself is never modified permanently in main storage, and the subject instruction cannot be another *execute* instruction.

PAGE

EX

Normally, instruction sequencing continues with the instruction following the execute instruction. However, if the instruction at the operand 2 address is a successful branch instruction, the instruction address field of the current PSW is replaced by the branch address and instruction sequencing continues with the instruction located at the branch address. If the operand 2 instruction is branch and link or branch and link external, the instruction address stored in the link register is that of the instruction following the execute instruction.

#### **Explicit Format:**

| LABEL    | $\Delta$ OPERATION $\Delta$ | OPERAND                                                          |
|----------|-----------------------------|------------------------------------------------------------------|
| [symbol] | EX                          | r <sub>1</sub> ,d <sub>2</sub> (x <sub>2</sub> ,b <sub>2</sub> ) |

#### Implicit Format:

| LABEL    | $\Delta$ OPERATION $\Delta$ | OPERAND                                          |
|----------|-----------------------------|--------------------------------------------------|
| [symbol] | EX                          | r <sub>1</sub> ,s <sub>2</sub> (x <sub>2</sub> ) |

#### **Operational Considerations:**

- If an interrupt occurs after the completion of the subject instruction, the old PSW contains the address of the instruction following the execute instruction or the branch address.
- The condition code may be set by the instruction at the operand 2 address.
- Possible program exception:
  - Specification exception (The address specified by operand 2 is an odd-numbered address.)

#### NOTE:

A program exception condition can be caused by the execute instruction or the instruction specified in the execute instruction.

## HDR\*

#### Floating Point

|       |                                                                                                                   | General        | a                        | Possible                                                                | e Program Exceptions                                                                                 |
|-------|-------------------------------------------------------------------------------------------------------------------|----------------|--------------------------|-------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------|
| OPCO  | DE                                                                                                                | FORMAT<br>TYPE | OBJECT<br>INST.<br>LGTH. | ☐ ADDRESSING ☐ DATA (INVALID SIGN/DIGIT)                                | ☐ PROTECTION ☐ SIGNIFICANCE                                                                          |
| MNEM. | HEX.                                                                                                              |                | (BYTES)                  | DECIMAL DIVIDE                                                          | SPECIFICATION:                                                                                       |
| HDR   | 24                                                                                                                | RR             | 2                        | DECIMAL OVERFLOW EXECUTE                                                | NOT A FLOATING-POINT REGISTER  OP 1 NOT ON HALF-WORD BOUNDARY                                        |
|       | Condition Codes                                                                                                   |                | S                        | EXPONENT OVERFLOW  EXPONENT UNDERFLOW                                   | OP 2 NOT ON HALF-WORD BOUNDARY OP 2 NOT ON FULL-WORD BOUNDARY                                        |
| IF RE | ☐ IF RESULT = 0, SET TO 0 ☐ IF RESULT < 0, SET TO 1 ☐ IF RESULT > 0, SET TO 2 ☐ IF OVERFLOW, SET TO 3 ■ UNCHANGED |                | ) 1<br>) 2               | FIXED-POINT DIVIDE FIXED-POINT OVERFLOW FLOATING-POINT DIVIDE OPERATION | OP 2 NOT ON DOUBLE-WORD BOUNDARY OP 1 NOT EVEN NUMBERED REGISTER OP 1 NOT ODD NUMBERED REGISTER NONE |

#### Function:

Causes the double-word contents of the operand 2 ( $r_2$ ) register to be divided by 2. The normalized quotient is placed in the double-word operand 1 ( $r_1$ ) register.

## Explicit and Implicit Format:

| LABEL    | $\Delta$ operation $\Delta$ | OPERAND                        |
|----------|-----------------------------|--------------------------------|
| [symbol] | HDR                         | r <sub>1</sub> ,r <sub>2</sub> |

- The fraction of operand 2 (r<sub>2</sub>) is shifted right one bit position. The least significant bit of the fraction is placed into the most significant bit position of the guard digit, and the vacated fraction bit position is filled with zero. The intermediate result is normalized and placed in the operand 1 (r<sub>1</sub>) location.
- When normalization causes the exponent to become less than zero, an exponent underflow condition exists. If the exponent underflow mask bit of the current program status word (PSW) is 1, the exponent of the result is 128 greater than the correct value. If the exponent underflow mask bit of the current PSW is zero, the result is made true zero.
- When the fraction of operand 2 (r₂) is zero, the result is made a true zero, a normalization is not attempted, and a significance exception does not occur.

<sup>\*</sup> HDR is a featured instruction. If you attempt to issue this instruction to a processor which does not have the control feature installed, you cause an operation program exception.

HER\*

|                 |                                                                                                                   | General                 |         | Possible                                                                | Program Exceptions                                                                                   |
|-----------------|-------------------------------------------------------------------------------------------------------------------|-------------------------|---------|-------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------|
| орсо            | DE                                                                                                                | FORMAT INST. TYPE LGTH. |         | ☐ ADDRESSING ☐ DATA (INVALID SIGN/DIGIT)                                | PROTECTION SIGNIFICANCE                                                                              |
| MNEM.           | HEX.                                                                                                              | , , , , _               | (BYTES) | DECIMAL DIVIDE                                                          | SPECIFICATION:                                                                                       |
| HER             | 34                                                                                                                | RR                      | 2       | DECIMAL OVERFLOW EXECUTE                                                | NOT A FLOATING-POINT REGISTER  OP 1 NOT ON HALF-WORD BOUNDARY                                        |
| Condition Codes |                                                                                                                   |                         | s       | EXPONENT OVERFLOW  EXPONENT UNDERFLOW                                   | OP 2 NOT ON HALF-WORD BOUNDARY OP 2 NOT ON FULL-WORD BOUNDARY OP 2 NOT ON DOUBLE-WORD                |
| ☐ IF RE☐ IF OV  | ☐ IF RESULT = 0, SET TO 0 ☐ IF RESULT < 0, SET TO 1 ☐ IF RESULT > 0, SET TO 2 ☐ IF OVERFLOW, SET TO 3 ■ UNCHANGED |                         |         | FIXED-POINT DIVIDE FIXED-POINT OVERFLOW FLOATING-POINT DIVIDE OPERATION | OP 2 NOT ON DOUBLE-WORD BOUNDARY OP 1 NOT EVEN NUMBERED REGISTER OP 1 NOT ODD NUMBERED REGISTER NONE |

#### Function:

Causes the full-word contents of the operand 2 ( $r_2$ ) register to be divided by 2. The normalized quotient is placed in the full word in the operand 1 ( $r_1$ ) register.

## **Explicit and Implicit Format:**

| LABEL    | $\Delta$ OPERATION $\Delta$ | OPERAND                        |
|----------|-----------------------------|--------------------------------|
| [symbol] | HER                         | r <sub>1</sub> ,r <sub>2</sub> |

- The fraction of operand 2 (r<sub>2</sub>) is shifted right one bit position. The least significant bit of the fraction is placed into the most significant bit position of the guard digit, and the vacated fraction bit position is filled with zero. The intermediate result is normalized and placed in the operand 1 (r<sub>1</sub>) location.
- When normalization causes the exponent to become less than zero, an exponent underflow condition exists. If the exponent underflow mask bit of the current program status word (PSW) is 1, the exponent of the result is 128 greater than the correct value. If the exponent underflow mask bit of the current PSW is zero, the result is made true zero.
- When the fraction of operand 2 (r₂) is zero, the result is made a true zero, normalization is not attempted, and a significance exception does not occur.

<sup>\*</sup> HER is a featured instruction. If you attempt to issue this instruction to a processor which does not have the control feature installed, you cause an operation program exception.

# **HPR**

|       |                                                                                                                   | General        |                          | Possible                                                  | e Program Exceptions                                                                  |
|-------|-------------------------------------------------------------------------------------------------------------------|----------------|--------------------------|-----------------------------------------------------------|---------------------------------------------------------------------------------------|
| ОРСО  | DE                                                                                                                | FORMAT<br>TYPE | OBJECT<br>INST.<br>LGTH. | ☐ ADDRESSING ☐ DATA (INVALID SIGN/DIGIT)                  | PROTECTION SIGNIFICANCE                                                               |
| MNEM. | HEX.                                                                                                              |                | (BYTES)                  | DECIMAL DIVIDE                                            | SPECIFICATION:  NOT A FLOATING-POINT REGISTER                                         |
| HPR   | 99                                                                                                                | SI             | 4                        | EXECUTE                                                   | OP 1 NOT ON HALF-WORD BOUNDARY                                                        |
|       | Condition Codes                                                                                                   |                |                          | EXPONENT OVERFLOW  EXPONENT UNDERFLOW  FIXED-POINT DIVIDE | OP 2 NOT ON HALF-WORD BOUNDARY OP 2 NOT ON FULL-WORD BOUNDARY OP 2 NOT ON DOUBLE-WORD |
| IF RE | ☐ IF RESULT = 0, SET TO 0 ☐ IF RESULT < 0, SET TO 1 ☐ IF RESULT > 0, SET TO 2 ☐ IF OVERFLOW, SET TO 3 ■ UNCHANGED |                |                          | FIXED-POINT OVERFLOW  FLOATING-POINT DIVIDE  OPERATION    | BOUNDARY  OP 1 NOT EVEN NUMBERED REGISTER  OP 1 NOT ODD NUMBERED REGISTER  NONE       |

Function:

Alters the current relocation register.

**Explicit Format:** 

| LABEL    | $\Delta$ OPERATION $\Delta$ | OPERAND                                          |
|----------|-----------------------------|--------------------------------------------------|
| [symbol] | HPR                         | d <sub>1</sub> (b <sub>1</sub> ), i <sub>2</sub> |

Implicit Format:

| LABEL    | $\Delta$ OPERATION $\Delta$ | OPERAND                         |  |  |
|----------|-----------------------------|---------------------------------|--|--|
| [symbol] | HPR                         | s <sub>1</sub> , i <sub>2</sub> |  |  |

IC

|                 |                                                                                                                   | General                        |                                       | Possible                                                                              | Program Exceptions                                                                                   |
|-----------------|-------------------------------------------------------------------------------------------------------------------|--------------------------------|---------------------------------------|---------------------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------|
| орсо            | DE                                                                                                                | OBJECT FORMAT INST. TYPE LGTH. |                                       | ■ ADDRESSING □ DATA (INVALID SIGN/DIGIT)                                              | PROTECTION SIGNIFICANCE                                                                              |
| MNEM.           | HEX.                                                                                                              |                                | (BYTES)                               | DECIMAL DIVIDE                                                                        | SPECIFICATION:                                                                                       |
| IC              | 43                                                                                                                | RX                             | 4                                     | DECIMAL OVERFLOW EXECUTE                                                              | OP 1 NOT ON HALF-WORD BOUNDARY                                                                       |
| Condition Codes |                                                                                                                   | s                              | EXPONENT OVERFLOW  EXPONENT UNDERFLOW | OP 2 NOT ON HALF-WORD BOUNDARY OP 2 NOT ON FULL-WORD BOUNDARY OP 2 NOT ON DOUBLE-WORD |                                                                                                      |
| IF RE           | ☐ IF RESULT = 0, SET TO 0 ☐ IF RESULT < 0, SET TO 1 ☐ IF RESULT > 0, SET TO 2 ☐ IF OVERFLOW, SET TO 3 ■ UNCHANGED |                                |                                       | FIXED-POINT DIVIDE FIXED-POINT OVERFLOW FLOATING-POINT DIVIDE OPERATION               | OP 2 NOT ON DOUBLE-WORD BOUNDARY OP 1 NOT EVEN NUMBERED REGISTER OP 1 NOT ODD NUMBERED REGISTER NONE |

#### Function:

Causes one byte from the area in main storage specified by operand 2 to be moved into the least significant eight bits of the operand 1  $(r_1)$  register.

#### **Explicit Format:**

| LABEL    | $\Delta$ OPERATION $\Delta$ | OPERAND                                                          |
|----------|-----------------------------|------------------------------------------------------------------|
| [symbol] | IC                          | r <sub>1</sub> ,d <sub>2</sub> (x <sub>2</sub> ,b <sub>2</sub> ) |

#### Implicit Format:

| LABEL    | $\Delta$ OPERATION $\Delta$ | OPERAND                                          |
|----------|-----------------------------|--------------------------------------------------|
| [symbol] | IC ·                        | r <sub>1</sub> ,s <sub>2</sub> (x <sub>2</sub> ) |

- The contents of operand 2 remain unchanged.
- The contents of the most significant 24 bits of the operand 1 (r₁) register remain unchanged.
- Operand 2 may be an area in main storage defined as longer than one byte, but only one byte will be moved.

# ISK

|        |      | General                                                       |                          | Possible                                                                | e Program Exceptions                                                                                 |
|--------|------|---------------------------------------------------------------|--------------------------|-------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------|
| OPCODE |      | FORMAT<br>TYPE                                                | OBJECT<br>INST.<br>LGTH. | ADDRESSING DATA (INVALID SIGN/DIGIT)                                    |                                                                                                      |
| MNEM.  | HEX. |                                                               | (BYTES)                  | DECIMAL DIVIDE                                                          | SPECIFICATION:                                                                                       |
| ISK    | 09   | RR                                                            | 2                        | DECIMAL OVERFLOW                                                        | OP 1 NOT ON HALF-WORD BOUNDARY                                                                       |
|        | Conc | dition Code                                                   | s                        | EXPONENT OVERFLOW  EXPONENT UNDERFLOW                                   | OP 2 NOT ON HALF-WORD BOUNDARY OP 2 NOT ON FULL-WORD BOUNDARY OP 2 NOT ON DOUBLE-WORD                |
| IF RE  | SULT | ± 0, SET TO<br>< 0, SET TO<br>> 0, SET TO<br>OW, SET TO<br>ED | ) 1<br>) 2               | FIXED-POINT DIVIDE FIXED-POINT OVERFLOW FLOATING-POINT DIVIDE OPERATION | OP 2 NOT ON DOUBLE-WORD BOUNDARY OP 1 NOT EVEN NUMBERED REGISTER OP 1 NOT ODD NUMBERED REGISTER NONE |

Function:

Alters the contents and size of the protect key storage.

Explicit and Implicit Format:

| LABEL    | $\Delta$ OPERATION $\Delta$ | OPERAND                         |
|----------|-----------------------------|---------------------------------|
| [symbol] | ISK                         | r <sub>1</sub> , r <sub>2</sub> |

ī

|        |                                                                                                                   | General        |                          | Possible                                                                | e Program Exceptions                                                                                 |
|--------|-------------------------------------------------------------------------------------------------------------------|----------------|--------------------------|-------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------|
| OPCODE |                                                                                                                   | FORMAT<br>TYPE | OBJECT<br>INST.<br>LGTH. | ADDRESSING DATA (INVALID SIGN/DIGIT)                                    | PROTECTION SIGNIFICANCE                                                                              |
| MNEM.  | HEX.                                                                                                              | ,,,_           | (BYTES)                  | DECIMAL DIVIDE                                                          | SPECIFICATION:                                                                                       |
| L      | <b>58</b> ~                                                                                                       | RX             | 4                        | DECIMAL OVERFLOW EXECUTE                                                | OP 1 NOT ON HALF-WORD BOUNDARY                                                                       |
|        | Conc                                                                                                              | lition Code    | s                        | EXPONENT OVERFLOW  EXPONENT UNDERFLOW                                   | OP 2 NOT ON HALF-WORD BOUNDARY OP 2 NOT ON FULL-WORD BOUNDARY OP 2 NOT ON DOUBLE-WORD                |
| IF RE  | ☐ IF RESULT = 0, SET TO 0 ☐ IF RESULT < 0, SET TO 1 ☐ IF RESULT > 0, SET TO 2 ☐ IF OVERFLOW, SET TO 3 ☐ UNCHANGED |                |                          | FIXED-POINT DIVIDE FIXED-POINT OVERFLOW FLOATING-POINT DIVIDE OPERATION | OP 2 NOT ON DOUBLE-WORD BOUNDARY OP 1 NOT EVEN NUMBERED REGISTER OP 1 NOT ODD NUMBERED REGISTER NONE |

#### Function:

Causes the contents of operand 2, a full word in main storage, to be placed in the operand 1 register (r<sub>1</sub>).

## **Explicit Format:**

| LABEL    | $\Delta$ operation $\Delta$ | OPERAND                                                          |
|----------|-----------------------------|------------------------------------------------------------------|
| [symbol] | L                           | r <sub>1</sub> ,d <sub>2</sub> (x <sub>2</sub> ,b <sub>2</sub> ) |
|          | 1                           |                                                                  |

## Implicit Format:

| LABEL    | $\Delta$ OPERATION $\Delta$ | OPERAND                                          |
|----------|-----------------------------|--------------------------------------------------|
| [symbol] | L                           | r <sub>1</sub> ,s <sub>2</sub> (x <sub>2</sub> ) |

- Operand 2 is a full word in main storage on a full-word boundary.
- The contents of operand 2 remain unchanged.

## LA

|                     |                                                                                                                   | General                  |                                          | Possible                                                                | e Program Exceptions                                                                                 |
|---------------------|-------------------------------------------------------------------------------------------------------------------|--------------------------|------------------------------------------|-------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------|
| OPCODE FORMAT INST. |                                                                                                                   | OBJECT<br>INST.<br>LGTH. | ☐ ADDRESSING ☐ DATA (INVALID SIGN/DIGIT) | ☐ PROTECTION ☐ SIGNIFICANCE                                             |                                                                                                      |
| MNEM.               | HEX.                                                                                                              | ,                        | (BYTES)                                  | DECIMAL DIVIDE                                                          | SPECIFICATION:                                                                                       |
| LA                  | 41                                                                                                                | RX                       | 4                                        | DECIMAL OVERFLOW EXECUTE                                                | OP 1 NOT ON HALF WORD BOUNDARY                                                                       |
|                     | Condition Codes                                                                                                   |                          | s                                        | EXPONENT OVERFLOW  EXPONENT UNDERFLOW                                   | OP 2 NOT ON HALF-WORD BOUNDARY OP 2 NOT ON FULL-WORD BOUNDARY OP 2 NOT ON DOUBLE-WORD                |
| IF RE               | ☐ IF RESULT = 0, SET TO 0 ☐ IF RESULT < 0, SET TO 1 ☐ IF RESULT > 0, SET TO 2 ☐ IF OVERFLOW, SET TO 3 ■ UNCHANGED |                          |                                          | FIXED-POINT DIVIDE FIXED-POINT OVERFLOW FLOATING-POINT DIVIDE OPERATION | OP 2 NOT ON DOUBLE-WORD BOUNDARY OP 1 NOT EVEN NUMBERED REGISTER OP 1 NOT ODD NUMBERED REGISTER NONE |

#### Function:

Causes the main storage address or the self-defining term specified by operand 2 to be loaded into the least significant 24 bits of the operand 1  $(r_1)$  register. The eight most significant bits of the operand 1  $(r_1)$  register are set to zeros.

## **Explicit Format:**

| LABEL    | $\Delta$ OPERATION $\Delta$ | OPERAND                                                          |
|----------|-----------------------------|------------------------------------------------------------------|
| [symbol] | LA                          | r <sub>1</sub> ,d <sub>2</sub> (x <sub>2</sub> ,b <sub>2</sub> ) |

#### Implicit Format:

| LABEL    | $\Delta$ OPERATION $\Delta$ |                                | OPERAND |  |
|----------|-----------------------------|--------------------------------|---------|--|
| [symbol] | LA                          | r <sub>1</sub> ,s <sub>2</sub> |         |  |

- The generated address is not checked for validity.
- The contents of operand 2 remain unchanged.
- If only the x<sub>2</sub> or b<sub>2</sub> register is used and is the same as the operand 1 (r<sub>1</sub>) register, the content of the operand 1 (r<sub>1</sub>) register is incremented by the decimal value d<sub>2</sub>.
- If operand 2 is expressed as a decimal value without the reference of any register, then operand 1 (r<sub>1</sub>) is loaded with the operand 2 decimal value.

**LCDR\*** 

**Floating Point** 

|                                                                                                                 |      | General        |                          | Possible                                                                | e Program Exceptions                                                                                 |
|-----------------------------------------------------------------------------------------------------------------|------|----------------|--------------------------|-------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------|
| OPCODE                                                                                                          |      | FORMAT<br>TYPE | OBJECT<br>INST.<br>LGTH. | -   -   -   -   -   -   -   -   -                                       | ☐ PROTECTION ☐ SIGNIFICANCE                                                                          |
| MNEM.                                                                                                           | HEX. |                | (BYTES)                  | DECIMAL DIVIDE                                                          | SPECIFICATION:                                                                                       |
| LCDR                                                                                                            | 23   | RR             | 2                        | DECIMAL OVERFLOW EXECUTE                                                | NOT A FLOATING-POINT REGISTER  OP 1 NOT ON HALF-WORD BOUNDARY                                        |
|                                                                                                                 | Conc | lition Code    | s                        | EXPONENT OVERFLOW  EXPONENT UNDERFLOW                                   | OP 2 NOT ON HALF-WORD BOUNDARY  OP 2 NOT ON FULL-WORD BOUNDARY  OP 2 NOT ON DOUBLE-WORD              |
| IF RESULT = 0, SET TO 0  IF RESULT < 0, SET TO 1  IF RESULT > 0, SET TO 2  ☐ IF OVERFLOW, SET TO 3  ☐ UNCHANGED |      |                | ) 1<br>) 2               | FIXED-POINT DIVIDE FIXED-POINT OVERFLOW FLOATING-POINT DIVIDE OPERATION | OP 2 NOT ON DOUBLE-WORD BOUNDARY OP 1 NOT EVEN NUMBERED REGISTER OP 1 NOT ODD NUMBERED REGISTER NONE |

#### Function:

Causes the sign of the double-word contents of the operand 2  $(r_2)$  register to be reversed. The result is placed in the double-word operand 1  $(r_1)$  register.

## **Explicit and Implicit Format:**

| LABEL    | $\Delta$ OPERATION $\Delta$ | OPERAND                        |
|----------|-----------------------------|--------------------------------|
| [symbol] | LCDR                        | r <sub>1</sub> ,r <sub>2</sub> |

- The exponent and fraction are not changed.
- The contents of operand 2 (r<sub>2</sub>) remain unchanged.

AGE

## LCER\*

## Floating Point

|        |                                                                                                         | General     |                          | Possible                                                                | e Program Exceptions                                                                                 |
|--------|---------------------------------------------------------------------------------------------------------|-------------|--------------------------|-------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------|
| OPCODE |                                                                                                         | FORMAT TYPE | OBJECT<br>INST.<br>LGTH. | \ \ \ \ \ \ \ \ \ \ \ \ \ \ \ \ \ \ \                                   | ☐ PROTECTION ☐ SIGNIFICANCE                                                                          |
| MNEM.  | HEX.                                                                                                    |             | (BYTES)                  | DECIMAL DIVIDE                                                          | SPECIFICATION:                                                                                       |
| LCER   | 33                                                                                                      | RR          | 2                        | ☐ EXECUTE                                                               | NOT A FLOATING-POINT REGISTER  OP 1 NOT ON HALF-WORD BOUNDARY                                        |
|        | Conc                                                                                                    | lition Code | s                        | EXPONENT OVERFLOW  EXPONENT UNDERFLOW                                   | OP 2 NOT ON HALF-WORD BOUNDARY OP 2 NOT ON FULL-WORD BOUNDARY OP 2 NOT ON DOUBLE-WORD                |
| IF RE  | IF RESULT = 0, SET TO 0 IF RESULT < 0, SET TO 1 IF RESULT > 0, SET TO 2 IF OVERFLOW, SET TO 3 UNCHANGED |             |                          | FIXED-POINT DIVIDE FIXED-POINT OVERFLOW FLOATING-POINT DIVIDE OPERATION | OP 2 NOT ON DOUBLE-WORD BOUNDARY OP 1 NOT EVEN NUMBERED REGISTER OP 1 NOT ODD NUMBERED REGISTER NONE |

#### Function:

Causes the sign of the full-word contents of the operand 2 ( $r_2$ ) register to be reversed. The result is placed in the full-word operand 1 ( $r_1$ ) register.

## **Explicit and Implicit Format:**

| LABEL    | $\Delta$ OPERATION $\Delta$ | OPERAND                        |
|----------|-----------------------------|--------------------------------|
| [symbol] | LCER                        | r <sub>1</sub> ,r <sub>2</sub> |

- The exponent and fraction are not changed.
- The contents of operand 2 (r<sub>2</sub>) remain unchanged.

LCR\*

PAGE

| General                                                                                                     |      |    |                                         | Possible                                                                | e Program Exceptions                                                                                 |
|-------------------------------------------------------------------------------------------------------------|------|----|-----------------------------------------|-------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------|
| OPCODE FORMAT INST. TYPE LGTH.                                                                              |      |    | ☐ ADDRESSING☐ DATA (INVALID SIGN/DIGIT) | PROTECTION SIGNIFICANCE                                                 |                                                                                                      |
| MNEM.                                                                                                       | HEX. |    | (BYTES)                                 | DECIMAL DIVIDE                                                          | SPECIFICATION:                                                                                       |
| LCR                                                                                                         | 13   | RR | 2                                       | DECIMAL OVERFLOW  EXECUTE                                               | OP 1 NOT ON HALF-WORD BOUNDARY                                                                       |
| Condition Codes                                                                                             |      |    | s                                       | EXPONENT OVERFLOW  EXPONENT UNDERFLOW                                   | OP 2 NOT ON HALF-WORD BOUNDARY OP 2 NOT ON FULL-WORD BOUNDARY                                        |
| IF RESULT = 0, SET TO 0  IF RESULT < 0, SET TO 1  IF RESULT > 0, SET TO 2  IF OVERFLOW, SET TO 3  UNCHANGED |      |    | ) 1<br>) 2                              | FIXED-POINT DIVIDE FIXED-POINT OVERFLOW FLOATING-POINT DIVIDE OPERATION | OP 2 NOT ON DOUBLE-WORD BOUNDARY OP 1 NOT EVEN NUMBERED REGISTER OP 1 NOT ODD NUMBERED REGISTER NONE |

#### Function:

Causes the twos complement of the value of the contents of the operand 2 register  $(r_2)$  to be placed in the operand 1  $(r_1)$  register.

#### **Explicit and Implicit Format:**

| LABE  | L    | $\Delta$ OPERATION $\Delta$ |                                | OPERAND |  |
|-------|------|-----------------------------|--------------------------------|---------|--|
| [syml | ool] | LCR                         | r <sub>1</sub> ,r <sub>2</sub> |         |  |

- The twos complement of the second operand is placed in the first operand location.
- A fixed-point overflow condition exists when the maximum negative number is complemented; the number remains unchanged. Zero remains unchanged under complementation.
- Operand 2 (r<sub>2</sub>) remains unchanged.

LCR is a featured instruction. If you attempt to issue this instruction to a processor which does not have the control feature installed, you cause an operation program exception.

# **LCS**

|          |                                               |    | General        |                                     | Possible                                                                | e Program Exceptions                                                                                 |
|----------|-----------------------------------------------|----|----------------|-------------------------------------|-------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------|
| 1        | OPCC                                          |    | FORMAT<br>TYPE | OBJECT<br>INST.<br>LGTH.<br>(BYTES) | ADDRESSING DATA (INVALID SIGN/DIGIT) DECIMAL DIVIDE                     | PROTECTION SIGNIFICANCE SPECIFICATION:                                                               |
|          | LCS                                           | B1 | RS             | 4                                   | DECIMAL OVERFLOW  EXECUTE                                               | OP 2 NOT ON HALF-WORD BOUNDARY  OP 2 NOT ON HALF-WORD BOUNDARY                                       |
| <b>†</b> | Condition Codes                               |    |                | :s                                  | EXPONENT OVERFLOW  EXPONENT UNDERFLOW                                   | OP 2 NOT ON FULL-WORD BOUNDARY                                                                       |
|          | SET TO 0 SET TO 1 SET TO 2 SET TO 3 UNCHANGED |    |                |                                     | FIXED POINT DIVIDE FIXED POINT OVERFLOW FLOATING POINT DIVIDE OPERATION | OP 2 NOT ON DOUBLE-WORD BOUNDARY OP 1 NOT EVEN NUMBERED REGISTER OP 1 NOT ODD NUMBERED REGISTER NONE |

Function:

Transfers data from main storage to control storage.

**Explicit Format:** 

| LABEL    | $\Delta$ OPERATION $\Delta$ | OPERAND                                                            |
|----------|-----------------------------|--------------------------------------------------------------------|
| [symbol] | LCS                         | r <sub>1</sub> , r <sub>3</sub> , d <sub>2</sub> (b <sub>2</sub> ) |

Implicit Format:

| LABEL    | $\Delta$ OPERATION $\Delta$ | OPERAND                                          |
|----------|-----------------------------|--------------------------------------------------|
| [symbol] | LCS                         | r <sub>1</sub> , r <sub>3</sub> , s <sub>2</sub> |

UPDATE LEVEL

2-68a PAGE

LD\*

Floating Point

|                                                                                                                   |                                | General |            | Possible                                                                        | Program Exceptions                                                                                   |
|-------------------------------------------------------------------------------------------------------------------|--------------------------------|---------|------------|---------------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------|
| ОРСО                                                                                                              | OPCODE FORMAT INST. TYPE LGTH. |         |            | ■ ADDRESSING □ DATA (INVALID SIGN/DIGIT)                                        | PROTECTION SIGNIFICANCE                                                                              |
| MNEM.                                                                                                             | HEX.                           | ,,,,_   | (BYTES)    | DECIMAL DIVIDE                                                                  | SPECIFICATION:                                                                                       |
| LD                                                                                                                | 68                             | RX      | 4          | DECIMAL OVERFLOW EXECUTE                                                        | NOT A FLOATING-POINT REGISTER  OP 1 NOT ON HALF-WORD BOUNDARY                                        |
| Condition Codes                                                                                                   |                                |         | s          | EXPONENT OVERFLOW  EXPONENT UNDERFLOW                                           | OP 2 NOT ON HALF-WORD BOUNDARY OP 2 NOT ON FULL-WORD BOUNDARY                                        |
| ☐ IF RESULT = 0, SET TO 0 ☐ IF RESULT < 0, SET TO 1 ☐ IF RESULT > 0, SET TO 2 ☐ IF OVERFLOW, SET TO 3 ☐ UNCHANGED |                                |         | ) 1<br>) 2 | ☐ FIXED-POINT DIVIDE ☐ FIXED-POINT OVERFLOW ☐ FLOATING-POINT DIVIDE ■ OPERATION | OP 2 NOT ON DOUBLE-WORD BOUNDARY OP 1 NOT EVEN NUMBERED REGISTER OP 1 NOT ODD NUMBERED REGISTER NONE |

#### Function:

Causes the contents of a double word in storage specified by operand 2 to be placed in the double word in the operand 1  $(r_1)$  register.

## **Explicit Format:**

| LABEL    | $\Delta$ OPERATION $\Delta$ | OPERAND                                                          |
|----------|-----------------------------|------------------------------------------------------------------|
| [symbol] | LD                          | r <sub>1</sub> ,d <sub>2</sub> (x <sub>2</sub> ,b <sub>2</sub> ) |

#### Implicit Format:

| LABEL    | $\Delta$ OPERATION $\Delta$ | OPERAND                                          |
|----------|-----------------------------|--------------------------------------------------|
| [symbol] | LD                          | r <sub>1</sub> ,s <sub>2</sub> (x <sub>2</sub> ) |

#### **Operational Consideration:**

The contents of operand 2 remain unchanged.

LD is a featured instruction. If you attempt to issue this instruction to a processor which does not have the control feature installed, you cause an operation program exception.

| • |   |   |  |
|---|---|---|--|
|   |   |   |  |
|   |   |   |  |
|   |   |   |  |
|   |   |   |  |
|   |   |   |  |
|   |   |   |  |
|   |   |   |  |
|   |   | • |  |
|   |   |   |  |
|   |   |   |  |
|   |   |   |  |
|   |   |   |  |
|   |   |   |  |
|   |   |   |  |
|   |   |   |  |
|   |   |   |  |
|   | , |   |  |
|   |   |   |  |
|   |   |   |  |
|   |   |   |  |
|   |   |   |  |
|   |   |   |  |
|   |   |   |  |
|   |   |   |  |
|   |   |   |  |
|   |   |   |  |
|   |   |   |  |
|   |   |   |  |
|   |   |   |  |
|   |   |   |  |

LDR\*

Floating Point

| General                                                                                                           |                                |    |            | Possible                                                           | e Program Exceptions                                                                                 |
|-------------------------------------------------------------------------------------------------------------------|--------------------------------|----|------------|--------------------------------------------------------------------|------------------------------------------------------------------------------------------------------|
| орсс                                                                                                              | OPCODE FORMAT INST. TYPE LGTH. |    |            | ☐ ADDRESSING ☐ DATA (INVALID SIGN/DIGIT)                           | PROTECTION SIGNIFICANCE                                                                              |
| MNEM.                                                                                                             | HEX.                           |    | (BYTES)    | DECIMAL DIVIDE                                                     | SPECIFICATION:  NOT A FLOATING-POINT REGISTER                                                        |
| LDR                                                                                                               | 28                             | RR | 2          | EXECUTE                                                            | OP 1 NOT ON HALF-WORD BOUNDARY                                                                       |
| Condition Codes                                                                                                   |                                |    |            | EXPONENT OVERFLOW  EXPONENT UNDERFLOW                              | OP 2 NOT ON HALF-WORD BOUNDARY OP 2 NOT ON FULL-WORD BOUNDARY OP 2 NOT ON DOUBLE-WORD                |
| ☐ IF RESULT = 0, SET TO 0 ☐ IF RESULT < 0, SET TO 1 ☐ IF RESULT > 0, SET TO 2 ☐ IF OVERFLOW, SET TO 3 ☐ UNCHANGED |                                |    | ) 1<br>) 2 | FIXED-POINT DIVIDE FIXED-POINT OVERFLOW STATEMENT DIVIDE OPERATION | OP 2 NOT ON DOUBLE-WORD BOUNDARY OP 1 NOT EVEN NUMBERED REGISTER OP 1 NOT ODD NUMBERED REGISTER NONE |

#### Function:

Causes the contents of the double word in the operand 2  $(r_2)$  register to be placed in the double word in the operand 1  $(r_1)$  register.

**Explicit and Implicit Format:** 

| LABEL    | $\Delta$ OPERATION $\Delta$ | OPERAND                        |
|----------|-----------------------------|--------------------------------|
| [symbol] | LDR                         | r <sub>1</sub> ,r <sub>2</sub> |
|          |                             |                                |

## Operational Consideration:

■ The contents of operand 2 (r₂) remain unchanged.

LDR is a featured instruction. If you attempt to issue this instruction to a processor which does not have the control feature installed, you cause an operation program exception.

# LE\* Floating Point

| General |                                                                                                                   |                |                          | Possible Program Exceptions                                             |                                                                                                      |  |
|---------|-------------------------------------------------------------------------------------------------------------------|----------------|--------------------------|-------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------|--|
| 1       |                                                                                                                   | FORMAT<br>TYPE | OBJECT<br>INST.<br>LGTH. | ADDRESSING DATA (INVALID SIGN/DIGIT)                                    | l <del></del>                                                                                        |  |
| MNEM.   | HEX.                                                                                                              |                | (BYTES)                  | DECIMAL DIVIDE                                                          | SPECIFICATION:                                                                                       |  |
| LE      | 78                                                                                                                | RX             | 4                        | DECIMAL OVERFLOW EXECUTE                                                | NOT A FLOATING-POINT REGISTER OP 1 NOT ON HALF-WORD BOUNDARY                                         |  |
|         | Condition Codes                                                                                                   |                |                          | EXPONENT OVERFLOW  EXPONENT UNDERFLOW                                   | OP 2 NOT ON HALF-WORD BOUNDARY OP 2 NOT ON FULL-WORD BOUNDARY                                        |  |
| IF RE   | ☐ IF RESULT = 0, SET TO 0 ☐ IF RESULT < 0, SET TO 1 ☐ IF RESULT > 0, SET TO 2 ☐ IF OVERFLOW, SET TO 3 ☐ UNCHANGED |                |                          | FIXED-POINT DIVIDE FIXED-POINT OVERFLOW FLOATING-POINT DIVIDE OPERATION | OP 2 NOT ON DOUBLE-WORD BOUNDARY OP 1 NOT EVEN NUMBERED REGISTER OP 1 NOT ODD NUMBERED REGISTER NONE |  |

## Function:

Causes the contents of a full word in storage specified by operand 2 to be placed in a full word in the operand 1  $(r_1)$  register.

## **Explicit Format:**

| LABEL    | $\Delta$ OPERATION $\Delta$ | OPERAND                                                          |
|----------|-----------------------------|------------------------------------------------------------------|
| [symbol] | LE                          | r <sub>1</sub> ,d <sub>2</sub> (x <sub>2</sub> ,b <sub>2</sub> ) |

## Implicit Format:

| LABEL  |    | $\Delta$ operation $\Delta$ | OPERAND                                          |
|--------|----|-----------------------------|--------------------------------------------------|
| [symbo | I] | LE .                        | r <sub>1</sub> ,s <sub>2</sub> (x <sub>2</sub> ) |

## Operational Consideration:

The contents of operand 2 remain unchanged.

LE is a featured instruction. If you attempt to issue this instruction to a processor which does not have the control feature installed, you cause an operation program exception.

LER\*

Floating Point

| General                                                                                                           |                 |                |                          | Possible Program Exceptions                                                   |                                                                                                      |  |
|-------------------------------------------------------------------------------------------------------------------|-----------------|----------------|--------------------------|-------------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------|--|
| OPCODE                                                                                                            |                 | FORMAT<br>TYPE | OBJECT<br>INST.<br>LGTH. |                                                                               | PROTECTION SIGNIFICANCE SPECIFICATION:                                                               |  |
| MNEM.                                                                                                             | HEX.            | ' ' -   -      |                          | DECIMAL DIVIDE                                                                |                                                                                                      |  |
| LER                                                                                                               | 38              | RR             | 2                        | DECIMAL OVERFLOW EXECUTE                                                      | NOT A FLOATING-POINT REGISTER  OP 1 NOT ON HALF-WORD BOUNDARY                                        |  |
|                                                                                                                   | Condition Codes |                |                          | EXPONENT OVERFLOW  EXPONENT UNDERFLOW                                         | OP 2 NOT ON HALF-WORD BOUNDARY OP 2 NOT ON FULL-WORD BOUNDARY                                        |  |
| ☐ IF RESULT = 0, SET TO 0 ☐ IF RESULT < 0, SET TO 1 ☐ IF RESULT > 0, SET TO 2 ☐ IF OVERFLOW, SET TO 3 ☐ UNCHANGED |                 |                |                          | FIXED-POINT DIVIDE FIXED-POINT OVERFLOW STORM FLOATING-POINT DIVIDE OPERATION | OP 2 NOT ON DOUBLE-WORD BOUNDARY OP 1 NOT EVEN NUMBERED REGISTER OP 1 NOT ODD NUMBERED REGISTER NONE |  |

#### Function:

Causes the contents of a full word in the operand 2 ( $r_2$ ) register to be placed in a full word in the operand 1 ( $r_1$ ) register.

**Explicit and Implicit Format:** 

| LABEL    | $\Delta$ OPERATION $\Delta$ | OPERAND                        |
|----------|-----------------------------|--------------------------------|
| [symbol] | LER                         | r <sub>1</sub> ,r <sub>2</sub> |

## **Operational Consideration:**

The contents of operand 2 (r<sub>2</sub>) remain unchanged.

<sup>\*</sup> LER is a featured instruction. If you attempt to issue this instruction to a processor which does not have the control feature installed, you cause an operation program exception.

PAGE

8227 Rev. 2

**UP-NUMBER** 

| General                                                                                                           |                 |                |                          | Possible Program Exceptions                                             |                                                                                                      |  |
|-------------------------------------------------------------------------------------------------------------------|-----------------|----------------|--------------------------|-------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------|--|
| OPCODE                                                                                                            |                 | FORMAT<br>TYPE | OBJECT<br>INST.<br>LGTH. | ADDRESSING DATA (INVALID SIGN/DIGIT)                                    | PROTECTION SIGNIFICANCE                                                                              |  |
| MNEM.                                                                                                             | HEX.            | 1,,,           | (BYTES)                  | DECIMAL DIVIDE                                                          | SPECIFICATION:                                                                                       |  |
| LH                                                                                                                | 48              | RX             | 4                        | ☐ EXECUTE                                                               | OP 1 NOT ON HALF-WORD BOUNDARY                                                                       |  |
|                                                                                                                   | Condition Codes |                |                          | EXPONENT OVERFLOW  EXPONENT UNDERFLOW                                   | OP 2 NOT ON HALF-WORD BOUNDARY OP 2 NOT ON FULL-WORD BOUNDARY                                        |  |
| ☐ IF RESULT = 0, SET TO 0 ☐ IF RESULT < 0, SET TO 1 ☐ IF RESULT > 0, SET TO 2 ☐ IF OVERFLOW, SET TO 3 ☐ UNCHANGED |                 |                |                          | FIXED-POINT DIVIDE FIXED-POINT OVERFLOW FLOATING-POINT DIVIDE OPERATION | OP 2 NOT ON DOUBLE-WORD BOUNDARY OP 1 NOT EVEN NUMBERED REGISTER OP 1 NOT ODD NUMBERED REGISTER NONE |  |

#### Function:

Causes the contents of operand 2, a half word in main storage, to be expanded and placed in the operand 1 register (r<sub>1</sub>).

## **Explicit Format:**

| _ | LABEL    | $\Delta$ operation $\Delta$ | OPERAND                                                          |
|---|----------|-----------------------------|------------------------------------------------------------------|
|   | [symbol] | LH                          | r <sub>1</sub> ,d <sub>2</sub> (x <sub>2</sub> ,b <sub>2</sub> ) |

#### Implicit Format:

| LAB  | EL   | $\Delta$ OPERATION $\Delta$ |                                                  | OPERAND |  |
|------|------|-----------------------------|--------------------------------------------------|---------|--|
| [sym | bol] | LH .                        | r <sub>1</sub> ,s <sub>2</sub> (x <sub>2</sub> ) |         |  |

- Operand 2 is a half word in main storage on a half-word boundary.
- The contents of operand 2 remain unchanged.
- Operand 2 is placed in the register of operand 1 (r<sub>1</sub>) and then is expanded to a full word by propagating the sign bit through the most significant bits.

LM

PAGE

| General                                                                                                           |                 |                |                          | Possible Program Exceptions                                                   |                                                                                                      |  |
|-------------------------------------------------------------------------------------------------------------------|-----------------|----------------|--------------------------|-------------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------|--|
| OPCODE                                                                                                            |                 | FORMAT<br>TYPE | OBJECT<br>INST.<br>LGTH. | ■ ADDRESSING □ DATA (INVALID SIGN/DIGIT)                                      | PROTECTION SIGNIFICANCE                                                                              |  |
| MNEM.                                                                                                             | HEX.            | , , ,          | (BYTES)                  | DECIMAL DIVIDE                                                                | SPECIFICATION:                                                                                       |  |
| LM                                                                                                                | 98              | RS             | 4                        | DECIMAL OVERFLOW  EXECUTE                                                     | OP 1 NOT ON HALF-WORD BOUNDARY                                                                       |  |
|                                                                                                                   | Condition Codes |                |                          | EXPONENT OVERFLOW  EXPONENT UNDERFLOW                                         | OP 2 NOT ON HALF-WORD BOUNDARY OP 2 NOT ON FULL-WORD BOUNDARY                                        |  |
| ☐ IF RESULT = 0, SET TO 0 ☐ IF RESULT < 0, SET TO 1 ☐ IF RESULT > 0, SET TO 2 ☐ IF OVERFLOW, SET TO 3 ☐ UNCHANGED |                 |                |                          | FIXED-POINT DIVIDE FIXED-POINT OVERFLOW STORM FLOATING-POINT DIVIDE OPERATION | OP 2 NOT ON DOUBLE-WORD BOUNDARY OP 1 NOT EVEN NUMBERED REGISTER OP 1 NOT ODD NUMBERED REGISTER NONE |  |

#### Function:

Causes the contents of operand 2, one or more full words in main storage, to be placed in the registers of operand 1  $(r_1)$  through operand 3  $(r_3)$ .

## **Explicit Format:**

| LABEL    | $\Delta$ OPERATION $\Delta$ | OPERAND                                                          |
|----------|-----------------------------|------------------------------------------------------------------|
| [symbol] | LM                          | r <sub>1</sub> ,r <sub>3</sub> ,d <sub>2</sub> (b <sub>2</sub> ) |

#### Implicit Format:

| LABEL    | $\Delta$ OPERATION $\Delta$ |                                                | OPERAND |  |
|----------|-----------------------------|------------------------------------------------|---------|--|
| [symbol] | LM ·                        | r <sub>1</sub> ,r <sub>3</sub> ,s <sub>2</sub> |         |  |

- The general registers, starting with the register specified by operand 1  $(r_1)$  and ending with the register specified by operand 3  $(r_3)$ , are loaded with full words from main storage, beginning with the address specified by operand 2  $(r_2)$ .
- The registers are loaded in ascending numeric sequence, beginning with the register specified by operand 1  $(r_1)$  and continuing through the register specified by operand 3  $(r_3)$ .

- One register may be loaded by specifying the same register for both operand 1  $(r_1)$  and operand 3  $(r_3)$ .
- If the register specified by operand 3 (r<sub>3</sub>) is lower than the register specified by operand 1 (r<sub>1</sub>), then the register specified by operand 1 (r<sub>1</sub>) and all registers with a number greater than operand 1 (r<sub>1</sub>) plus the register specified by operand 3 (r<sub>3</sub>) and all registers with a number less than operand 3 (r<sub>3</sub>) are loaded.
- The contents of operand 2, in main storage, remain unchanged. Operand 2 must be on a full-word boundary.

LNDR\*
Floating Point

|                                                                                                             |                 | General                        |         | Possible                                                                   | e Program Exceptions                                                                                 |  |
|-------------------------------------------------------------------------------------------------------------|-----------------|--------------------------------|---------|----------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------|--|
| OPCODE                                                                                                      |                 | OBJECT FORMAT INST. TYPE LGTH. |         | ☐ ADDRESSING ☐ DATA (INVALID SIGN/DIGIT)                                   | PROTECTION SIGNIFICANCE                                                                              |  |
| MNEM.                                                                                                       | HEX.            |                                | (BYTES) | DECIMAL DIVIDE                                                             | SPECIFICATION:                                                                                       |  |
| LNDR                                                                                                        | 21              | RR                             | 2       | DECIMAL OVERFLOW EXECUTE                                                   | NOT A FLOATING-POINT REGISTER  OP 1 NOT ON HALF-WORD BOUNDARY                                        |  |
|                                                                                                             | Condition Codes |                                |         | EXPONENT OVERFLOW  EXPONENT UNDERFLOW                                      | OP 2 NOT ON HALF-WORD BOUNDARY  OP 2 NOT ON FULL-WORD BOUNDARY  OP 2 NOT ON DOUBLE-WORD              |  |
| IF RESULT = 0, SET TO 0  IF RESULT < 0, SET TO 1  IF RESULT > 0, SET TO 2  IF OVERFLOW, SET TO 3  UNCHANGED |                 |                                |         | FIXED-POINT DIVIDE  FIXED-POINT OVERFLOW  FLOATING-POINT DIVIDE  OPERATION | OP 2 NOT ON DOUBLE-WORD BOUNDARY OP 1 NOT EVEN NUMBERED REGISTER OP 1 NOT ODD NUMBERED REGISTER NONE |  |

#### Function:

Causes the sign of the double word in the operand 2  $(r_2)$  register to be made negative. The result is placed in the double-word register specified by operand 1  $(r_1)$ .

### **Explicit and Implicit Format:**

| LABEL    | $\Delta$ OPERATION $\Delta$ | OPERAND                        |
|----------|-----------------------------|--------------------------------|
| [symbol] | LNDR                        | r <sub>1</sub> ,r <sub>2</sub> |

- Operand 2 (r<sub>2</sub>) is made negative even if the fraction is zero.
- The exponent and fraction are not changed.
- The contents of operand 2 (r<sub>2</sub>) remain unchanged.

<sup>\*</sup> LNDR is a featured instruction. If you attempt to issue this instruction to a processor which does not have the control feature installed, you cause an operation program exception.

PAGE

### Floating Point

|       |                      | General                                                       |                          | Possible                                                                | e Program Exceptions                                                                                 |
|-------|----------------------|---------------------------------------------------------------|--------------------------|-------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------|
| орсо  | DE                   | FORMAT<br>TYPE                                                | OBJECT<br>INST.<br>LGTH. | ☐ ADDRESSING ☐ DATA (INVALID SIGN/DIGIT)                                | ☐ PROTECTION ☐ SIGNIFICANCE                                                                          |
| MNEM. | HEX.                 | , , , , _                                                     | (BYTES)                  | DECIMAL DIVIDE                                                          | SPECIFICATION:                                                                                       |
| LNER  | 31                   | RR                                                            | 2                        | DECIMAL OVERFLOW EXECUTE                                                | NOT A FLOATING-POINT REGISTER  OP 1 NOT ON HALF-WORD BOUNDARY                                        |
|       | Conc                 | lition Code                                                   | s                        | EXPONENT OVERFLOW  EXPONENT UNDERFLOW                                   | OP 2 NOT ON HALF-WORD BOUNDARY OP 2 NOT ON FULL-WORD BOUNDARY                                        |
| IF RE | SULT<br>SULT<br>ERFL | = 0, SET TO<br>< 0, SET TO<br>> 0, SET TO<br>OW, SET TO<br>ED | ) 1<br>) 2               | FIXED-POINT DIVIDE FIXED-POINT OVERFLOW FLOATING-POINT DIVIDE OPERATION | OP 2 NOT ON DOUBLE-WORD BOUNDARY OP 1 NOT EVEN NUMBERED REGISTER OP 1 NOT ODD NUMBERED REGISTER NONE |

#### Function:

Causes the sign of a full word in the operand  $2(r_2)$  register to be made negative. The result is placed in a full word in the register specified by operand 1  $(r_1)$ .

### **Explicit and Implicit Format:**

| LABEL    | $\Delta$ OPERATION $\Delta$ | OPERAND                        |
|----------|-----------------------------|--------------------------------|
| [symbol] | LNER                        | r <sub>1</sub> ,r <sub>2</sub> |

- Operand 2 (r<sub>2</sub>) is made negative even if the fraction is zero.
- The exponent and fraction are not changed.
- The contents of operand 2 (r₂) remain unchanged.

<sup>\*</sup> LNER is a featured instruction. If you attempt to issue this instruction to a processor which does not have the control feature installed, you cause an operation program exception.

LNR\*

|                                                                                                             |      | General        |                          | Possible                                                                | e Program Exceptions                                                                                 |  |
|-------------------------------------------------------------------------------------------------------------|------|----------------|--------------------------|-------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------|--|
| OPCODE                                                                                                      |      | FORMAT<br>TYPE | OBJECT<br>INST.<br>LGTH. | ☐ ADDRESSING ☐ DATA (INVALID SIGN/DIGIT)                                | PROTECTION SIGNIFICANCE                                                                              |  |
| MNEM.                                                                                                       | HEX. |                | (BYTES)                  | DECIMAL DIVIDE                                                          | SPECIFICATION:                                                                                       |  |
| LNR                                                                                                         | 11   | RR             | 2                        | DECIMAL OVERFLOW EXECUTE                                                | ☐ NOT A FLOATING-POINT REGISTER ☐ OP 1 NOT ON HALF-WORD BOUNDARY                                     |  |
| Condition Codes                                                                                             |      |                |                          | EXPONENT OVERFLOW  EXPONENT UNDERFLOW                                   | OP 2 NOT ON HALF-WORD BOUNDARY  OP 2 NOT ON FULL-WORD BOUNDARY  OP 2 NOT ON DOUBLE-WORD              |  |
| IF RESULT = 0, SET TO 0  IF RESULT < 0, SET TO 1  IF RESULT > 0, SET TO 2  IF OVERFLOW, SET TO 3  UNCHANGED |      |                |                          | FIXED-POINT DIVIDE FIXED-POINT OVERFLOW FLOATING-POINT DIVIDE OPERATION | OP 2 NOT ON DOUBLE WORD BOUNDARY OP 1 NOT EVEN NUMBERED REGISTER OP 1 NOT ODD NUMBERED REGISTER NONE |  |

#### Function:

Causes the twos complement of the absolute value of the contents of the operand 2 and register  $(r_2)$  to be placed in the operand 1  $(r_1)$  register.

# **Explicit and Implicit:**

| $\Delta$ operation $\Delta$ | OPERAND                        |
|-----------------------------|--------------------------------|
| LNR                         | r <sub>1</sub> ,r <sub>2</sub> |
|                             |                                |

- The twos complement of the absolute value of the second operand  $(r_2)$  is placed in the first operand  $(r_1)$  location.
- The operation complements positive numbers; negative numbers and zero remain unchanged.
- Operand 2 (r<sub>2</sub>) remains unchanged.

LNR is a featured instruction. If you attempt to issue this instruction to a processor which does not have the control feature installed, you cause an operation program exception.

# LPDR\*

## **Floating Point**

|         |                      | General                                                       |                                     | Possible                                                  | Program Exceptions                                                                    |
|---------|----------------------|---------------------------------------------------------------|-------------------------------------|-----------------------------------------------------------|---------------------------------------------------------------------------------------|
| OPCO    |                      | FORMAT<br>TYPE                                                | OBJECT<br>INST.<br>LGTH.<br>(BYTES) | ☐ ADDRESSING ☐ DATA (INVALID SIGN/DIGIT) ☐ DECIMAL DIVIDE | ☐ PROTECTION ☐ SIGNIFICANCE ■ SPECIFICATION:                                          |
| LPDR    | 20                   | RR                                                            | 2                                   | DECIMAL OVERFLOW EXECUTE                                  | NOT A FLOATING-POINT REGISTER  OP 1 NOT ON HALF-WORD BOUNDARY                         |
|         | Condition Codes      |                                                               |                                     | EXPONENT OVERFLOW  EXPONENT UNDERFLOW  FIXED-POINT DIVIDE | OP 2 NOT ON HALF-WORD BOUNDARY OP 2 NOT ON FULL-WORD BOUNDARY OP 2 NOT ON DOUBLE-WORD |
| ☐ IF RE | SULT<br>SULT<br>ERFL | = 0, SET TO<br>< 0, SET TO<br>> 0, SET TO<br>OW, SET TO<br>ED | ) 1<br>) 2                          | FIXED-POINT DIVIDE FIXED-POINT OVERFLOW OPERATION         | BOUNDARY  OP 1 NOT EVEN NUMBERED REGISTER  OP 1 NOT ODD NUMBERED REGISTER  NONE       |

### Function:

Causes the sign of the double word in the operand 2  $(r_2)$  register to be positive. The result is placed in the double word of the operand 1  $(r_1)$  register.

## **Explicit and Implicit Format:**

| LABEL    | $\Delta$ operation $\Delta$ | OPERAND                        |
|----------|-----------------------------|--------------------------------|
| [symbol] | LPDR                        | r <sub>1</sub> ,r <sub>2</sub> |

- The exponent and fraction are not changed.
- The contents of operand 2 (r<sub>2</sub>) remain unchanged.

LPDR is a featured instruction. If you attempt to issue this instruction to a processor which does not have the control feature installed, you cause an operation program exception.

LPER\*

Floating Point

|                                                                                                                     |                 | General        |                          | Possible                                                                | e Program Exceptions                                                                                 |  |
|---------------------------------------------------------------------------------------------------------------------|-----------------|----------------|--------------------------|-------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------|--|
| OPCODE                                                                                                              |                 | FORMAT<br>TYPE | OBJECT<br>INST.<br>LGTH. | DATA (INVALID SIGN/DIGIT)                                               | ☐ PROTECTION ☐ SIGNIFICANCE                                                                          |  |
| MNEM.                                                                                                               | HEX.            |                | (BYTES)                  | DECIMAL DIVIDE                                                          | SPECIFICATION:  NOT A FLOATING-POINT REGISTER                                                        |  |
| LPER                                                                                                                | 30              | RR             | 2                        | EXECUTE                                                                 | OP 1 NOT ON HALF-WORD BOUNDARY                                                                       |  |
|                                                                                                                     | Condition Codes |                |                          | EXPONENT OVERFLOW  EXPONENT UNDERFLOW                                   | OP 2 NOT ON HALF-WORD BOUNDARY OP 2 NOT ON FULL-WORD BOUNDARY OP 2 NOT ON DOUBLE-WORD                |  |
| IF RESULT = 0, SET TO 0  ☐ IF RESULT < 0, SET TO 1  ☐ IF RESULT > 0, SET TO 2  ☐ IF OVERFLOW, SET TO 3  ☐ UNCHANGED |                 |                |                          | FIXED-POINT DIVIDE FIXED-POINT OVERFLOW FLOATING-POINT DIVIDE OPERATION | OP 2 NOT ON DOUBLE-WORD BOUNDARY OP 1 NOT EVEN NUMBERED REGISTER OP 1 NOT ODD NUMBERED REGISTER NONE |  |

### Function:

Causes the sign of a full word in the operand 2  $(r_2)$  register to be positive. The result is placed in a full word of the operand 1  $(r_1)$  register.

### **Explicit and Implicit Format:**

| LABEL    | $\Delta$ OPERATION $\Delta$ | OPERAND                        |
|----------|-----------------------------|--------------------------------|
| [symbol] | LPER                        | r <sub>1</sub> ,r <sub>2</sub> |

- The exponent and fraction are not changed.
- The contents of operand 2 (r<sub>2</sub>) remain unchanged.

# LPR\*

| General                                                                                                     |                 |                |                          | Possible                                                                | e Program Exceptions                                                                                 |  |
|-------------------------------------------------------------------------------------------------------------|-----------------|----------------|--------------------------|-------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------|--|
| OPCODE                                                                                                      |                 | FORMAT<br>TYPE | OBJECT<br>INST.<br>LGTH. | ☐ ADDRESSING ☐ DATA (INVALID SIGN/DIGIT)                                | PROTECTION SIGNIFICANCE                                                                              |  |
| MNEM.                                                                                                       | HEX.            |                | (BYTES)                  | DECIMAL DIVIDE                                                          | SPECIFICATION:                                                                                       |  |
| LPR                                                                                                         | 10              | RR             | 2                        | DECIMAL OVERFLOW EXECUTE                                                | OP 1 NOT ON HALF-WORD BOUNDARY                                                                       |  |
|                                                                                                             | Condition Codes |                |                          | EXPONENT OVERFLOW  EXPONENT UNDERFLOW                                   | OP 2 NOT ON HALF-WORD BOUNDARY OP 2 NOT ON FULL-WORD BOUNDARY OP 2 NOT ON DOUBLE-WORD                |  |
| IF RESULT = 0, SET TO 0  IF RESULT < 0, SET TO 1  IF RESULT > 0, SET TO 2  IF OVERFLOW, SET TO 3  UNCHANGED |                 |                |                          | FIXED-POINT DIVIDE FIXED-POINT OVERFLOW FLOATING-POINT DIVIDE OPERATION | OP 2 NOT ON DOUBLE-WORD BOUNDARY OP 1 NOT EVEN NUMBERED REGISTER OP 1 NOT ODD NUMBERED REGISTER NONE |  |

#### Function:

Causes the absolute value of the contents of the operand 2 register  $(r_2)$  to be placed in the operand 1  $(r_1)$  register.

#### **Explicit and Implicit Format:**

| LABEL    | $\Delta$ OPERATION $\Delta$ | OPERAND                        |   |
|----------|-----------------------------|--------------------------------|---|
| [symbol] | LPR                         | r <sub>1</sub> ,r <sub>2</sub> | _ |

- Positive numbers remain unchanged. When the second operand  $(r_2)$  is negative, the twos complement is placed in the first operand  $(r_1)$  location.
- A fixed-point overflow condition exists and the number remains unchanged when the maximum negative number is complemented.
- Operand 2 (r<sub>2</sub>) remains unchanged.

<sup>\*</sup> LPR is a featured instruction. If you attempt to issue this instruction to a processor which does not have the control feature installed, you cause an operation program exception.

UPDATE LEVEL

2–80a PAGE

**LPSW** 

|         |                                                                | General        |                                     | Possible                                                                                                     | e Program Exceptions                                                                                                                |
|---------|----------------------------------------------------------------|----------------|-------------------------------------|--------------------------------------------------------------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------|
| OPCO    |                                                                | FORMAT<br>TYPE | OBJECT<br>INST.<br>LGTH.<br>(BYTES) | ■ ADDRESSING □ DATA (INVALID SIGN/DIGIT) □ DECIMAL DIVIDE                                                    | SPECIFICATION:                                                                                                                      |
| LPSW    | 82                                                             | SI             | 4                                   | ☐ DECIMAL OVERFLOW ☐ EXECUTE ☐ EXPONENT OVERFLOW                                                             | NOT A FLOATING-POINT REGISTER  OP 1 NOT ON HALF-WORD BOUNDARY  OP 2 NOT ON HALF-WORD BOUNDARY                                       |
| SET SET | Condition Codes  SET TO 0 SET TO 1 SET TO 2 SET TO 3 UNCHANGED |                | s                                   | EXPONENT OVERFLOW EXPONENT UNDERFLOW FIXED-POINT DIVIDE FIXED-POINT OVERFLOW FLOATING-POINT DIVIDE OPERATION | OP 2 NOT ON FULL-WORD BOUNDARY OP 1 NOT ON DOUBLE-WORD BOUNDARY OP 1 NOT EVEN NUMBERED REGISTER OP 1 NOT ODD NUMBERED REGISTER NONE |

Function:

Replaces all or part of the current PSW.

**Explicit Format:** 

| LABEL    | $\triangle$ OPERATION $\triangle$ | OPERAND                                          |
|----------|-----------------------------------|--------------------------------------------------|
| [symbol] | LPSW                              | d <sub>1</sub> (b <sub>1</sub> ), i <sub>2</sub> |

Implicit Format:

| LABEL    | $\triangle$ OPERATION $\triangle$ | OPERAND                         |  |
|----------|-----------------------------------|---------------------------------|--|
| [symbol] | LPSW                              | s <sub>1</sub> , i <sub>2</sub> |  |
|          |                                   |                                 |  |

| • |  |  |   |
|---|--|--|---|
|   |  |  |   |
|   |  |  |   |
|   |  |  |   |
|   |  |  |   |
|   |  |  |   |
|   |  |  |   |
|   |  |  |   |
|   |  |  |   |
|   |  |  |   |
|   |  |  |   |
|   |  |  |   |
|   |  |  |   |
|   |  |  | 1 |

LR

|                                                                                                                   |      | General |            | Possible                                                                | Program Exceptions                                                                                   |
|-------------------------------------------------------------------------------------------------------------------|------|---------|------------|-------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------|
| OPCODE FORMAT INST. TYPE LGTH.                                                                                    |      |         | <b>—</b>   | PROTECTION SIGNIFICANCE                                                 |                                                                                                      |
| MNEM.                                                                                                             | HEX. | ,,,,    | (BYTES)    | DECIMAL DIVIDE                                                          | SPECIFICATION:                                                                                       |
| LR                                                                                                                | 18   | RR      | 2          | DECIMAL OVERFLOW EXECUTE                                                | OP 1 NOT ON HALF-WORD BOUNDARY                                                                       |
| Condition Codes                                                                                                   |      |         | s          | EXPONENT OVERFLOW  EXPONENT UNDERFLOW                                   | OP 2 NOT ON HALF-WORD BOUNDARY OP 2 NOT ON FULL-WORD BOUNDARY OP 2 NOT ON DOUBLE-WORD                |
| ☐ IF RESULT = 0, SET TO 0 ☐ IF RESULT < 0, SET TO 1 ☐ IF RESULT > 0, SET TO 2 ☐ IF OVERFLOW, SET TO 3 ☐ UNCHANGED |      |         | ) 1<br>) 2 | FIXED-POINT DIVIDE FIXED-POINT OVERFLOW FLOATING-POINT DIVIDE OPERATION | OP 2 NOT ON DOUBLE-WORD BOUNDARY OP 1 NOT EVEN NUMBERED REGISTER OP 1 NOT ODD NUMBERED REGISTER NONE |

### Function:

Causes the contents of the register specified by operand 2  $(r_2)$  to be loaded into the register specified by operand 1  $(r_1)$ .

### **Explicit and Implicit Format:**

| LABEL    | $\Delta$ OPERATION $\Delta$ | OPERAND                        |
|----------|-----------------------------|--------------------------------|
| [symbol] | LR                          | r <sub>1</sub> ,r <sub>2</sub> |

- The contents of the register specified by operand 2 (r<sub>2</sub>) are loaded into the register specified by operand 1 (r<sub>1</sub>).
- The contents of the register specified by operand 2 (r₂) remain unchanged.

# LTDR\*

### **Floating Point**

|                               |                                                                                                             | General        |                          | Possible                                                                | Program Exceptions                                                                                   |
|-------------------------------|-------------------------------------------------------------------------------------------------------------|----------------|--------------------------|-------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------|
| OPCODE                        |                                                                                                             | FORMAT<br>TYPE | OBJECT<br>INST.<br>LGTH. | ☐ ADDRESSING ☐ DATA (INVALID SIGN/DIGIT)                                | PROTECTION SIGNIFICANCE                                                                              |
| MNEM.                         | HEX.                                                                                                        | 1176           | (BYTES)                  | DECIMAL DIVIDE                                                          | SPECIFICATION:                                                                                       |
| LTDR                          | 22                                                                                                          | RR             | 2                        | DECIMAL OVERFLOW EXECUTE                                                | NOT A FLOATING-POINT REGISTER  OP 1 NOT ON HALF-WORD BOUNDARY                                        |
|                               | Condition Codes                                                                                             |                | s                        | EXPONENT OVERFLOW  EXPONENT UNDERFLOW                                   | OP 2 NOT ON HALF-WORD BOUNDARY OP 2 NOT ON FULL-WORD BOUNDARY OP 2 NOT ON DOUBLE-WORD                |
| ■ IF RE<br>■ IF RE<br>□ IF OV | IF RESULT = 0, SET TO 0  IF RESULT < 0, SET TO 1  IF RESULT > 0, SET TO 2  IF OVERFLOW, SET TO 3  UNCHANGED |                |                          | FIXED-POINT DIVIDE FIXED-POINT OVERFLOW FLOATING-POINT DIVIDE OPERATION | OP 2 NOT ON DOUBLE-WORD BOUNDARY OP 1 NOT EVEN NUMBERED REGISTER OP 1 NOT ODD NUMBERED REGISTER NONE |

#### Function:

Causes the double-word contents of the operand 2  $(r_2)$  register to be placed in the double-word operand 1  $(r_1)$  register. The condition code is set by this instruction.

# **Explicit and Implicit Format:**

| LABEL    | $\Delta$ OPERATION $\Delta$ |                                | OPERAND |  |
|----------|-----------------------------|--------------------------------|---------|--|
| [symbol] | LTDR                        | r <sub>1</sub> ,r <sub>2</sub> |         |  |

- The contents of operand 2 (r<sub>2</sub>) remain unchanged.
- When the same register is specified by operand 1 (r₁) and operand 2 (r₂), the operation is equivalent to a test without data movement.

<sup>\*</sup> LTDR is a featured instruction. If you attempt to issue this instruction to a processor which does not have the control feature installed, you cause an operation program exception.

Floating Point

|                                                                                                             |                                 | General |            | Possible                                                                | e Program Exceptions                                                                                 |  |
|-------------------------------------------------------------------------------------------------------------|---------------------------------|---------|------------|-------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------|--|
| орсо                                                                                                        | OPCODE FORMAT INST.  TYPE LGTH. |         |            | ☐ ADDRESSING ☐ DATA (INVALID SIGN/DIGIT)                                | PROTECTION SIGNIFICANCE                                                                              |  |
| MNEM.                                                                                                       | HEX.                            | , , ,   | (BYTES)    | DECIMAL DIVIDE                                                          | SPECIFICATION:                                                                                       |  |
| LTER                                                                                                        | 32                              | RR      | 2          | DECIMAL OVERFLOW EXECUTE                                                | NOT A FLOATING-POINT REGISTER  OP 1 NOT ON HALF-WORD BOUNDARY                                        |  |
| Condition Codes                                                                                             |                                 |         | S          | EXPONENT OVERFLOW  EXPONENT UNDERFLOW                                   | OP 2 NOT ON HALF-WORD BOUNDARY  OP 2 NOT ON FULL-WORD BOUNDARY  OP 2 NOT ON DOUBLE-WORD              |  |
| IF RESULT = 0, SET TO 0  IF RESULT < 0, SET TO 1  IF RESULT > 0, SET TO 2  IF OVERFLOW, SET TO 3  UNCHANGED |                                 |         | ) 1<br>) 2 | FIXED-POINT DIVIDE FIXED-POINT OVERFLOW FLOATING-POINT DIVIDE OPERATION | OP 2 NOT ON DOUBLE-WORD BOUNDARY OP 1 NOT EVEN NUMBERED REGISTER OP 1 NOT ODD NUMBERED REGISTER NONE |  |

#### Function:

Causes the contents of a full word in the operand  $2(r_2)$  register to be placed in a full word in the operand  $1(r_1)$  register. The condition code is set by this instruction.

### **Explicit and Implicit Format:**

| LABEL    | $\Delta$ OPERATION $\Delta$ | OPERAND                        |
|----------|-----------------------------|--------------------------------|
| [symbol] | LTER                        | r <sub>1</sub> ,r <sub>2</sub> |

- The contents of operand 2 (r₂) remain unchanged.
- When the same register is specified by operand 1 (r₁) and operand 2 (r₂), the operation is equivalent to a test without data movement.

LTER is a featured instruction. If you attempt to issue this instruction to a processor which does not have the control feature installed, you cause an operation program exception.

|                |                                                                                                         | General        |                          | Possibl                                                                 | e Program Exceptions                                                                                 |
|----------------|---------------------------------------------------------------------------------------------------------|----------------|--------------------------|-------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------|
| 1 ' = '        |                                                                                                         | FORMAT<br>TYPE | OBJECT<br>INST.<br>LGTH. | ☐ ADDRESSING ☐ DATA (INVALID SIGN/DIGIT)                                | PROTECTION SIGNIFICANCE                                                                              |
| MNEM.          | HEX.                                                                                                    |                | (BYTES)                  | DECIMAL DIVIDE                                                          | SPECIFICATION:                                                                                       |
| LTR            | 12                                                                                                      | RR             | 2                        | DECIMAL OVERFLOW SECUTE                                                 | OP 1 NOT ON HALF-WORD BOUNDARY                                                                       |
|                | Condition Codes                                                                                         |                |                          | EXPONENT OVERFLOW  EXPONENT UNDERFLOW                                   | OP 2 NOT ON HALF-WORD BOUNDARY OP 2 NOT ON FULL-WORD BOUNDARY                                        |
| IF RE<br>IF RE | IF RESULT = 0, SET TO 0 IF RESULT < 0, SET TO 1 IF RESULT > 0, SET TO 2 IF OVERFLOW, SET TO 3 UNCHANGED |                |                          | FIXED-POINT DIVIDE FIXED-POINT OVERFLOW FLOATING-POINT DIVIDE OPERATION | OP 2 NOT ON DOUBLE-WORD BOUNDARY OP 1 NOT EVEN NUMBERED REGISTER OP 1 NOT ODD NUMBERED REGISTER NONE |

Causes the contents of the register specified by operand 2  $(r_2)$  to be loaded into the register specified by operand 1  $(r_1)$  and the condition code to be set to reflect the value contained in the registers.

# Explicit and Implicit Format:

| LABEL    | $\Delta$ OPERATION $\Delta$ | OPERAND                        |
|----------|-----------------------------|--------------------------------|
| [symbol] | LTR                         | r <sub>1</sub> ,r <sub>2</sub> |

- The contents of the register specified by operand 2  $(r_2)$  are loaded into the register specified by operand 1  $(r_1)$ .
- The contents of the register specified by operand 2 (r₂) remain unchanged.

PAGE

|         |                                                                                         | General        |                          | Possible                                                                     | e Program Exceptions                                                                           |
|---------|-----------------------------------------------------------------------------------------|----------------|--------------------------|------------------------------------------------------------------------------|------------------------------------------------------------------------------------------------|
| ОРСС    |                                                                                         | FORMAT<br>TYPE | OBJECT<br>INST.<br>LGTH. | ADDRESSING DATA (INVALID SIGN/DIGIT) DECIMAL DIVIDE                          | PROTECTION SIGNIFICANCE SPECIFICATION:                                                         |
| MNEM.   | HEX.                                                                                    |                | (BYTES)                  | DECIMAL OVERFLOW                                                             | NOT A FLOATING-POINT REGISTER                                                                  |
| М       | 5C                                                                                      | RX             | 4                        | EXECUTE                                                                      | OP 1 NOT ON HALF-WORD BOUNDARY                                                                 |
| ☐ IF RE | Condition Codes  IF RESULT = 0, SET TO 0  IF RESULT < 0, SET TO 1                       |                |                          | EXPONENT OVERFLOW EXPONENT UNDERFLOW FIXED-POINT DIVIDE FIXED-POINT OVERFLOW | OP 2 NOT ON HALF-WORD BOUNDARY OP 2 NOT ON FULL-WORD BOUNDARY OP 2 NOT ON DOUBLE-WORD BOUNDARY |
|         | ☐ IF RESULT < 0, SET TO 1 ☐ IF RESULT > 0, SET TO 2 ☐ IF OVERFLOW, SET TO 3 ■ UNCHANGED |                |                          | FLOATING-POINT DIVIDE                                                        | OP 1 NOT EVEN NUMBERED REGISTER OP 1 NOT ODD NUMBERED REGISTER NONE                            |

#### Function:

Causes the contents of the odd register of the even-odd pair specified by operand  $1(r_1)$  to be multiplied by the contents of operand 2, a full word in main storage. The product is placed in the even-odd pair of registers specified by operand 1  $(r_1)$ .

# Explicit Format:

| LABEL    | $\Delta$ OPERATION $\Delta$ | OPERAND                                                          |
|----------|-----------------------------|------------------------------------------------------------------|
| [symbol] | М                           | r <sub>1</sub> ,d <sub>2</sub> (x <sub>2</sub> ,b <sub>2</sub> ) |

#### Implicit Format:

| LABEL    | $\Delta$ OPERATION $\Delta$ | OPERAND                                          |
|----------|-----------------------------|--------------------------------------------------|
| [symbol] | М                           | r <sub>1</sub> ,s <sub>2</sub> (x <sub>2</sub> ) |

- Both operands are treated as fixed-point, 32-bit signed integers.
- The contents of operand 2, the multiplier in a full word in main storage, remain unchanged.
- The product is treated as a 64-bit, fixed-point signed integer and occupies and even-odd register pair specified by operand 1 ( $r_1$ ).

M

- The multiplicand is first loaded into the odd-numbered register of the even-odd pair specified by operand 1 (r₁). The content of the even-numbered register is ignored until replaced by the most significant 32 bits of the product.
- The sign of the product is determined algebraically.
- A specification exception results if operand 2 is not on a full-word boundary and also if operand 1 (r<sub>1</sub>) specifies an odd-numbered register.

MD\*

PAGE

Floating Point

| General                                                                                                           |                 |                |                          | Possible Program Exceptions                                                     |                                                                                                      |  |
|-------------------------------------------------------------------------------------------------------------------|-----------------|----------------|--------------------------|---------------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------|--|
| OPCODE                                                                                                            |                 | FORMAT<br>TYPE | OBJECT<br>INST.<br>LGTH. | ADDRESSING DATA (INVALID SIGN/DIGIT)                                            | PROTECTION SIGNIFICANCE                                                                              |  |
| MNEM.                                                                                                             | HEX.            | , , , , _      | (BYTES)                  | DECIMAL DIVIDE                                                                  | SPECIFICATION:                                                                                       |  |
| MD                                                                                                                | 6C              | RX             | 4                        | DECIMAL OVERFLOW EXECUTE                                                        | NOT A FLOATING-POINT REGISTER  OP 1 NOT ON HALF-WORD BOUNDARY                                        |  |
|                                                                                                                   | Condition Codes |                |                          | EXPONENT OVERFLOW  EXPONENT UNDERFLOW                                           | OP 2 NOT ON HALF-WORD BOUNDARY OP 2 NOT ON FULL-WORD BOUNDARY                                        |  |
| ☐ IF RESULT = 0, SET TO 0 ☐ IF RESULT < 0, SET TO 1 ☐ IF RESULT > 0, SET TO 2 ☐ IF OVERFLOW, SET TO 3 ☐ UNCHANGED |                 |                | ) 1<br>) 2               | ☐ FIXED-POINT DIVIDE ☐ FIXED-POINT OVERFLOW ☐ FLOATING-POINT DIVIDE ■ OPERATION | OP 2 NOT ON DOUBLE-WORD BOUNDARY OP 1 NOT EVEN NUMBERED REGISTER OP 1 NOT ODD NUMBERED REGISTER NONE |  |

### Function:

Causes the contents of the double word in the operand 1 ( $r_1$ )register to be multiplied by the contents of a double word in main storage specified by operand 2. The normalized product is placed in the double word of the operand 1 ( $r_1$ ) register.

### **Explicit Format:**

| LABEL    | $\Delta$ OPERATION $\Delta$ | OPERAND                                                          |
|----------|-----------------------------|------------------------------------------------------------------|
| [symbol] | MD                          | r <sub>1</sub> ,d <sub>2</sub> (x <sub>2</sub> ,b <sub>2</sub> ) |

# Implicit Format:

| LABEL    | $\Delta$ OPERATION $\Delta$ | OPERAND                                          |
|----------|-----------------------------|--------------------------------------------------|
| [symbol] | MD                          | r <sub>1</sub> ,s <sub>2</sub> (x <sub>2</sub> ) |

<sup>\*</sup> MD is a featured instruction. If you attempt to issue this instruction to a processor which does not have the control feature installed, you cause an operation program exception.

# MDR\*

### Floating Point

| General                                                                                                           |                 |                |                          | Possible Program Exceptions                                             |                                                                                                      |  |
|-------------------------------------------------------------------------------------------------------------------|-----------------|----------------|--------------------------|-------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------|--|
| OPCODE                                                                                                            |                 | FORMAT<br>TYPE | OBJECT<br>INST.<br>LGTH. |                                                                         | ☐ PROTECTION ☐ SIGNIFICANCE                                                                          |  |
| MNEM.                                                                                                             | HEX.            | , , , _        | (BYTES)                  | DECIMAL DIVIDE                                                          | SPECIFICATION:                                                                                       |  |
| MDR                                                                                                               | 2C              | RR             | 2                        | DECIMAL OVERFLOW EXECUTE                                                | NOT A FLOATING-POINT REGISTER  OP 1 NOT ON HALF-WORD BOUNDARY                                        |  |
|                                                                                                                   | Condition Codes |                |                          | EXPONENT OVERFLOW  EXPONENT UNDERFLOW                                   | OP 2 NOT ON HALF-WORD BOUNDARY OP 2 NOT ON FULL-WORD BOUNDARY                                        |  |
| ☐ IF RESULT = 0, SET TO 0 ☐ IF RESULT < 0, SET TO 1 ☐ IF RESULT > 0, SET TO 2 ☐ IF OVERFLOW, SET TO 3 ■ UNCHANGED |                 |                |                          | FIXED-POINT DIVIDE FIXED-POINT OVERFLOW FLOATING-POINT DIVIDE OPERATION | OP 2 NOT ON DOUBLE-WORD BOUNDARY OP 1 NOT EVEN NUMBERED REGISTER OP 1 NOT ODD NUMBERED REGISTER NONE |  |

#### Function:

Causes the contents of the double word in the operand 1  $(r_1)$  register to be multiplied by the contents of the double word in the operand 2  $(r_2)$  register. The normalized product is placed in the double word of the operand 1  $(r_1)$  register.

# **Explicit and Implicit Format:**

| LABEL    | $\Delta$ OPERATION $\Delta$ | OPERAND                        |  |  |
|----------|-----------------------------|--------------------------------|--|--|
| [symbol] | MDR                         | r <sub>1</sub> ,r <sub>2</sub> |  |  |

<sup>\*</sup> MDR is a featured instruction. If you attempt to issue this instruction to a processor which does not have the control feature installed, you cause an operation program exception.

MEX

PAGE

**Floating Point** 

| General                                                                                                 |      |             |                          | Possible Program Exceptions                                             |                                                                                                      |  |
|---------------------------------------------------------------------------------------------------------|------|-------------|--------------------------|-------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------|--|
| OPCODE                                                                                                  |      | FORMAT TYPE | OBJECT<br>INST.<br>LGTH. | ■ ADDRESSING □ DATA (INVALID SIGN/DIGIT)                                | PROTECTION SIGNIFICANCE                                                                              |  |
| MNEM.                                                                                                   | HEX. | 11,5        | (BYTES)                  | DECIMAL DIVIDE                                                          | SPECIFICATION:                                                                                       |  |
| ME                                                                                                      | 7C   | RX          | 4                        | DECIMAL OVERFLOW  EXECUTE                                               | NOT A FLOATING-POINT REGISTER  OP 1 NOT ON HALF-WORD BOUNDARY                                        |  |
| Condition Codes                                                                                         |      |             |                          | EXPONENT OVERFLOW  EXPONENT UNDERFLOW                                   | OP 2 NOT ON HALF-WORD BOUNDARY OP 2 NOT ON FULL-WORD BOUNDARY OP 2 NOT ON DOUBLE-WORD                |  |
| IF RESULT = 0, SET TO 0 IF RESULT < 0, SET TO 1 IF RESULT > 0, SET TO 2 IF OVERFLOW, SET TO 3 UNCHANGED |      |             |                          | FIXED-POINT DIVIDE FIXED-POINT OVERFLOW FLOATING-POINT DIVIDE OPERATION | OP 2 NOT ON DOUBLE-WORD BOUNDARY OP 1 NOT EVEN NUMBERED REGISTER OP 1 NOT ODD NUMBERED REGISTER NONE |  |

#### Function:

Causes the contents of a full word in the operand 1  $(r_1)$  register to be multiplied by the contents of a full word in main storage specified by operand 2. The normalized product is placed in a full word of the operand 1  $(r_1)$  register.

# Explicit Format:

| LABEL   | △ OPERATION | Δ <b>OPERAND</b>                                                 |
|---------|-------------|------------------------------------------------------------------|
| [symbol | ] ME        | r <sub>1</sub> ,d <sub>2</sub> (x <sub>2</sub> ,b <sub>2</sub> ) |

### Implicit Format:

| LABEL    | $\Delta$ OPERATION $\Delta$ | OPERAND                                          | _ |
|----------|-----------------------------|--------------------------------------------------|---|
| [symbol] | ME                          | r <sub>1</sub> ,s <sub>2</sub> (x <sub>2</sub> ) | _ |

ME is a featured instruction. If you attempt to issue this instruction to a processor which does not have the control feature
installed, you cause an operation program exception.

# MER\*

### Floating Point

| General                                                                                                           |      |                |                          | Possible Program Exceptions                                             |                                                                                                      |  |
|-------------------------------------------------------------------------------------------------------------------|------|----------------|--------------------------|-------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------|--|
| OPCODE                                                                                                            |      | FORMAT<br>TYPE | OBJECT<br>INST.<br>LGTH. | ☐ ADDRESSING ☐ DATA (INVALID SIGN/DIGIT)                                | PROTECTION SIGNIFICANCE                                                                              |  |
| MNEM.                                                                                                             | HEX. | 1112           | (BYTES)                  | DECIMAL DIVIDE                                                          | SPECIFICATION:                                                                                       |  |
| MER                                                                                                               | 3C   | RR             | 2                        | DECIMAL OVERFLOW  EXECUTE                                               | NOT A FLOATING-POINT REGISTER  OP 1 NOT ON HALF-WORD BOUNDARY                                        |  |
| Condition Codes                                                                                                   |      |                | s                        | EXPONENT OVERFLOW  EXPONENT UNDERFLOW                                   | OP 2 NOT ON HALF-WORD BOUNDARY  OP 2 NOT ON FULL-WORD BOUNDARY  OP 2 NOT ON DOUBLE-WORD              |  |
| ☐ IF RESULT = 0, SET TO 0 ☐ IF RESULT < 0, SET TO 1 ☐ IF RESULT > 0, SET TO 2 ☐ IF OVERFLOW, SET TO 3 ☐ UNCHANGED |      |                | ) 1<br>) 2               | FIXED-POINT DIVIDE FIXED-POINT OVERFLOW FLOATING-POINT DIVIDE OPERATION | OP 2 NOT ON DOUBLE-WORD BOUNDARY OP 1 NOT EVEN NUMBERED REGISTER OP 1 NOT ODD NUMBERED REGISTER NONE |  |

#### Function:

Causes the contents of a full word in the operand 1  $(r_1)$  register to be multiplied by the contents of a full word in the operand 2  $(r_2)$  register. The normalized product is placed in a full word in the operand 1  $(r_1)$  register.

# **Explicit and Implicit Format:**

| LABEL    | $\Delta$ OPERATION $\Delta$ | OPERAND                        |  |  |
|----------|-----------------------------|--------------------------------|--|--|
| [symbol] | MER                         | r <sub>1</sub> ,r <sub>2</sub> |  |  |

<sup>\*</sup> MER is a featured instruction. If you attempt to issue this instruction to a processor which does not have the control feature installed, you cause an operation program exception.



Causes the contents of the register specified by operand 1  $(r_1)$  to be multiplied by the contents of operand 2, a half word in main storage. The product is placed in the register specified by operand 1  $(r_1)$ .

#### **Explicit Format:**

| LABEL    | $\Delta$ OPERATION $\Delta$ | OPERAND            |  |  |
|----------|-----------------------------|--------------------|--|--|
| [symbol] | мн                          | $r_1,d_2(x_2,b_2)$ |  |  |

#### Implicit Format:

| LABEL    | $\Delta$ OPERATION $\Delta$ | OPERAND                                          |  |  |
|----------|-----------------------------|--------------------------------------------------|--|--|
| [symbol] | мн                          | r <sub>1</sub> ,s <sub>2</sub> (x <sub>2</sub> ) |  |  |

- Operand 2 is expanded after being read from storage; then both operands are treated as fixed-point,
   32-bit signed integers.
- The contents of operand 2, the multiplier, a half word in main storage, remain unchanged.
- The sign of the product is determined algebraically.
- If the multiplication results in a product that exceeds 32 bits, the high-order bits are ignored but the overflow condition is not indicated. The sign and value of the product may not be correct after overflow.
- A specification exception will result if operand 2 is not on a half-word boundary.

MH is a featured instruction. If you attempt to issue this instruction to a processor which does not have the control feature
installed, you cause an operation program exception.

|     | General                                                                                                           |      |                |                          | Possible Program Exceptions                                             |                                                                                                      |  |
|-----|-------------------------------------------------------------------------------------------------------------------|------|----------------|--------------------------|-------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------|--|
|     | OPCODE                                                                                                            |      | FORMAT<br>TYPE | OBJECT<br>INST.<br>LGTH. | ■ ADDRESSING ■ DATA (INVALID SIGN/DIGIT)                                | ■ PROTECTION □ SIGNIFICANCE                                                                          |  |
|     | MNEM.                                                                                                             | HEX. | 11,72          | (BYTES)                  | DECIMAL DIVIDE                                                          | SPECIFICATION:                                                                                       |  |
|     | МР                                                                                                                | FC   | SS             | 6                        | DECIMAL OVERFLOW EXECUTE                                                | OP 1 NOT ON HALF-WORD BOUNDARY                                                                       |  |
|     | Condition Codes                                                                                                   |      |                | s                        | EXPONENT OVERFLOW  EXPONENT UNDERFLOW                                   | OP 2 NOT ON HALF-WORD BOUNDARY OP 2 NOT ON FULL-WORD BOUNDARY                                        |  |
| ] [ | ☐ IF RESULT = 0, SET TO 0 ☐ IF RESULT < 0, SET TO 1 ☐ IF RESULT > 0, SET TO 2 ☐ IF OVERFLOW, SET TO 3 ☐ UNCHANGED |      |                |                          | FIXED-POINT DIVIDE FIXED-POINT OVERFLOW FLOATING-POINT DIVIDE OPERATION | OP 2 NOT ON DOUBLE-WORD BOUNDARY OP 1 NOT EVEN NUMBERED REGISTER OP 1 NOT ODD NUMBERED REGISTER NONE |  |

Causes the contents of operand 1 to be multiplied by the contents of operand 2. The product is placed in the operand 1 location.

### **Explicit Format:**

| LABEL    | $\Delta$ OPERATION $\Delta$ | OPERAND                                                                                           |  |  |
|----------|-----------------------------|---------------------------------------------------------------------------------------------------|--|--|
| [symbol] | МР                          | d <sub>1</sub> (l <sub>1</sub> ,b <sub>1</sub> ),d <sub>2</sub> (l <sub>2</sub> ,b <sub>2</sub> ) |  |  |

### Implicit Format:

| LABEL    | $\Delta$ OPERATION $\Delta$ | OPERAND                                                           |
|----------|-----------------------------|-------------------------------------------------------------------|
| [symbol] | MP                          | s <sub>1</sub> (I <sub>1</sub> ),s <sub>2</sub> (I <sub>2</sub> ) |

- All signs and digits are checked for validity, and the sign of the product is determined algebraically.
- Operand 1 must be longer than operand 2.
- Operand 1 and operand 2 may overlap if their least significant bytes coincide.
- The size of the multiplier (operand 2) cannot be more than 15 digits and sign.

MP

PAGE

- The number of digits in the product is equal to the number of digits in the operands; therefore, the multiplicand (operand 1) must have a field of most significant zero digits to equal, in size, operand 2. The maximum product size is 31 digits. At least one most significant digit of the product field is zero.
- Data exception indicates one or more of the following conditions:
  - Invalid sign or digit code
  - Operand 1 has insufficient high-order zero digits
  - Incorrect overlap

| General                                                                                                           |                 |                |                                     | Possible Program Exceptions                                             |                                                                                       |  |
|-------------------------------------------------------------------------------------------------------------------|-----------------|----------------|-------------------------------------|-------------------------------------------------------------------------|---------------------------------------------------------------------------------------|--|
| OPCC                                                                                                              | T               | FORMAT<br>TYPE | OBJECT<br>INST.<br>LGTH.<br>(BYTES) | ☐ ADDRESSING ☐ DATA (INVALID SIGN/DIGIT) ☐ DECIMAL DIVIDE               | ☐ PROTECTION ☐ SIGNIFICANCE ■ SPECIFICATION:                                          |  |
| MR                                                                                                                | 10              | RR             | 2                                   | DECIMAL OVERFLOW EXECUTE                                                | □ NOT A FLOATING-POINT REGISTER □ OP 1 NOT ON HALF-WORD BOUNDARY                      |  |
|                                                                                                                   | Condition Codes |                |                                     | EXPONENT OVERFLOW  EXPONENT UNDERFLOW  FIXED-POINT DIVIDE               | OP 2 NOT ON HALF-WORD BOUNDARY OP 2 NOT ON FULL-WORD BOUNDARY OP 2 NOT ON DOUBLE-WORD |  |
| ☐ IF RESULT = 0, SET TO 0 ☐ IF RESULT < 0, SET TO 1 ☐ IF RESULT > 0, SET TO 2 ☐ IF OVERFLOW, SET TO 3 ☐ UNCHANGED |                 |                |                                     | FIXED-POINT DIVIDE FIXED-POINT OVERFLOW FLOATING-POINT DIVIDE OPERATION | BOUNDARY  OP 1 NOT EVEN NUMBERED REGISTER  OP 1 NOT ODD NUMBERED REGISTER  NONE       |  |

Causes the contents of the odd register of the even-odd pair specified by operand 1  $(r_1)$  to be multiplied by the contents of the register specified by operand 2  $(r_2)$ . The product is placed in the even-odd pair of registers specified by operand 1  $(r_1)$ .

# **Explicit and Implicit Format:**

| LABEL    | LABEL △ OPERATION △ |                                | OPERAND |  |  |
|----------|---------------------|--------------------------------|---------|--|--|
| [symbol] | MR                  | r <sub>1</sub> ,r <sub>2</sub> |         |  |  |

- Both operands are treated as fixed-point, 32-bit signed integers.
- The contents of operand 2 (r<sub>2</sub>), the multiplier, remain unchanged.
- The product is treated as a 64-bit, fixed-point signed integer and occupies an even-odd register pair specified by operand 1 (r<sub>1</sub>).
- The multiplicand is first loaded into the odd-numbered register of the even-odd pair specified by operand 1 (r<sub>1</sub>). The content of the even-numbered register is ignored until replaced by the most significant 32 bits of the product.
- The sign of the product is determined algebraically.
- A specification exception results if operand 1 (r<sub>1</sub>) specifies an odd-numbered register.

MR is a featured instruction. If you attempt to issue this instruction to a processor which does not have the control feature
installed, you cause an operation program exception.

| General                                                                                                           |      |                |                          | Possible Program Exceptions                                             |                                                                                                      |  |
|-------------------------------------------------------------------------------------------------------------------|------|----------------|--------------------------|-------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------|--|
| OPCODE                                                                                                            |      | FORMAT<br>TYPE | OBJECT<br>INST.<br>LGTH. | ADDRESSING DATA (INVALID SIGN/DIGIT)                                    | PROTECTION SIGNIFICANCE                                                                              |  |
| MNEM.                                                                                                             | HEX. | , , , _        | (BYTES)                  | DECIMAL DIVIDE                                                          | SPECIFICATION:                                                                                       |  |
| MVC                                                                                                               | D2   | SS             | 6                        | DECIMAL OVERFLOW EXECUTE                                                | OP 1 NOT ON HALF-WORD BOUNDARY                                                                       |  |
| Condition Codes                                                                                                   |      |                | s                        | EXPONENT OVERFLOW  EXPONENT UNDERFLOW                                   | OP 2 NOT ON HALF-WORD BOUNDARY OP 2 NOT ON FULL-WORD BOUNDARY OP 2 NOT ON DOUBLE-WORD                |  |
| ☐ IF RESULT = 0, SET TO 0 ☐ IF RESULT < 0, SET TO 1 ☐ IF RESULT > 0, SET TO 2 ☐ IF OVERFLOW, SET TO 3 ■ UNCHANGED |      |                |                          | FIXED-POINT DIVIDE FIXED-POINT OVERFLOW FLOATING-POINT DIVIDE OPERATION | OP 2 NOT ON DOUBLE-WORD BOUNDARY OP 1 NOT EVEN NUMBERED REGISTER OP 1 NOT ODD NUMBERED REGISTER NONE |  |

Causes the contents of the field in main storage specified by operand 2 to be placed in the field in main storage specified by operand 1.

# **Explicit Format:**

| LABEL    | $\Delta$ OPERATION $\Delta$ | OPERAND                                                             |  |  |
|----------|-----------------------------|---------------------------------------------------------------------|--|--|
| [symbol] | MVC                         | d <sub>1</sub> (I,b <sub>1</sub> ),d <sub>2</sub> (b <sub>2</sub> ) |  |  |

#### Implicit Format:

| LABEL    | $\Delta$ OPERATION $\Delta$ | OPERAND                           |
|----------|-----------------------------|-----------------------------------|
| [symbol] | MVC ·                       | s <sub>1</sub> (I),s <sub>2</sub> |

- The transfer proceeds from left to right.
- The number of bytes transferred is specified by 1 in operand 1.
- The contents of operand 2 remain unchanged unless operand 1 and operand 2 overlap.
- If the number of bytes to be moved is not explicitly shown in operand 1, then the number will be equal to the length attribute of operand 1.

| General                                                                                                           |                 |                |                          | Possible Program Exceptions                                                     |                                                                                                      |  |
|-------------------------------------------------------------------------------------------------------------------|-----------------|----------------|--------------------------|---------------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------|--|
| ОРСС                                                                                                              | DE              | FORMAT<br>TYPE | OBJECT<br>INST.<br>LGTH. | ■ ADDRESSING □ DATA (INVALID SIGN/DIGIT)                                        | PROTECTION SIGNIFICANCE                                                                              |  |
| MNEM.                                                                                                             | HEX.            |                | (BYTES)                  | DECIMAL DIVIDE                                                                  | SPECIFICATION:                                                                                       |  |
| MVI                                                                                                               | 92              | SI             | 4                        | DECIMAL OVERFLOW  EXECUTE                                                       | OP 1 NOT ON HALF-WORD BOUNDARY                                                                       |  |
|                                                                                                                   | Condition Codes |                |                          | EXPONENT OVERFLOW  EXPONENT UNDERFLOW                                           | OP 2 NOT ON HALF-WORD BOUNDARY  OP 2 NOT ON FULL-WORD BOUNDARY  OP 2 NOT ON DOUBLE-WORD              |  |
| ☐ IF RESULT = 0, SET TO 0 ☐ IF RESULT < 0, SET TO 1 ☐ IF RESULT > 0, SET TO 2 ☐ IF OVERFLOW, SET TO 3 ☐ UNCHANGED |                 |                |                          | ☐ FIXED-POINT DIVIDE ☐ FIXED-POINT OVERFLOW ☐ FLOATING-POINT DIVIDE ☐ OPERATION | OP 2 NOT ON DOUBLE-WORD BOUNDARY OP 1 NOT EVEN NUMBERED REGISTER OP 1 NOT ODD NUMBERED REGISTER NONE |  |

Causes the one byte of data used in the instruction as operand 2 to be moved into the one byte of main storage specified by operand 1.

# **Explicit Format:**

| LABEL   | △ OPERATION △ |                                                 | OPERAND | _ |
|---------|---------------|-------------------------------------------------|---------|---|
| [symbol | ] MVI         | d <sub>1</sub> (b <sub>1</sub> ),i <sub>2</sub> |         |   |

#### Implicit Format:

| LABEL    | $\Delta$ operation $\Delta$ | OPERAND                        |
|----------|-----------------------------|--------------------------------|
| [symbol] | MVI                         | s <sub>1</sub> ,i <sub>2</sub> |

- The immediate data in the instruction, operand 2, must specify one byte of data.
- The length attribute of the field specified by operand 1 may be longer than one byte, but only the one byte addressed by operand 1 will be replaced by the immediate data (operand 2).

|                                                                                                                   |      | General        |                                                                         | Possible                                                                                             | e Program Exceptions                                                                  |
|-------------------------------------------------------------------------------------------------------------------|------|----------------|-------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------|---------------------------------------------------------------------------------------|
| ОРСО                                                                                                              | DE   | FORMAT<br>TYPE | OBJECT<br>INST.<br>LGTH.                                                | ■ ADDRESSING □ DATA (INVALID SIGN/DIGIT)                                                             | PROTECTION SIGNIFICANCE                                                               |
| MNEM.                                                                                                             | HEX. | ,,,_           | (BYTES)                                                                 | DECIMAL DIVIDE                                                                                       | SPECIFICATION:                                                                        |
| MVN                                                                                                               | D1   | SS             | 6                                                                       | DECIMAL OVERFLOW EXECUTE                                                                             | NOT A FLOATING-POINT REGISTER  OP 1 NOT ON HALF-WORD BOUNDARY                         |
|                                                                                                                   | Cond | dition Code    | s                                                                       | EXPONENT OVERFLOW  EXPONENT UNDERFLOW                                                                | OP 2 NOT ON HALF-WORD BOUNDARY OP 2 NOT ON FULL-WORD BOUNDARY OP 2 NOT ON DOUBLE-WORD |
| ☐ IF RESULT = 0, SET TO 0 ☐ IF RESULT < 0, SET TO 1 ☐ IF RESULT > 0, SET TO 2 ☐ IF OVERFLOW, SET TO 3 ■ UNCHANGED |      | ) 1<br>) 2     | FIXED-POINT DIVIDE FIXED-POINT OVERFLOW FLOATING-POINT DIVIDE OPERATION | OP 2 NOT ON DOUBLE-WORD BOUNDARY OP 1 NOT EVEN NUMBERED REGISTER OP 1 NOT ODD NUMBERED REGISTER NONE |                                                                                       |

Causes the least significant four bits (the digit or numeric field) of each byte specified by operand 2 to be moved to the least significant four bits of each byte of operand 1.

#### **Explicit Format:**

| LABEL    | $\Delta$ OPERATION $\Delta$ | OPERAND                                                             | _ |
|----------|-----------------------------|---------------------------------------------------------------------|---|
| [symbol] | MVN                         | d <sub>1</sub> (I,b <sub>1</sub> ),d <sub>2</sub> (b <sub>2</sub> ) |   |

### Implicit Format:

| LABEL    | $\Delta$ operation $\Delta$ | OPERAND                           |
|----------|-----------------------------|-----------------------------------|
| [symbol] | MVN                         | s <sub>1</sub> (I),s <sub>2</sub> |

- The four most significant bits of each byte (zone field) remain unchanged.
- The contents of operand 2 remain unchanged unless there is overlapping.
- Overlapping of operands is permitted.
- The number of bytes transferred is specified by 1 in operand 1.
- If the number of bytes to be moved is not explicitly shown in operand 1, then the number will be equal to the length attribute of operand 1.

PAGE

# MVO

|                                                                                                                   |      | General     |                                      | Possible                                                                | e Program Exceptions                                                                                 |
|-------------------------------------------------------------------------------------------------------------------|------|-------------|--------------------------------------|-------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------|
| OPCODE FORMAT INST. TYPE LGTH.                                                                                    |      |             | ADDRESSING DATA (INVALID SIGN/DIGIT) | PROTECTION SIGNIFICANCE                                                 |                                                                                                      |
| MNEM.                                                                                                             | HEX. | 1112        | (BYTES)                              | DECIMAL DIVIDE                                                          | SPECIFICATION:                                                                                       |
| MVO                                                                                                               | F1   | SS          | 6                                    | DECIMAL OVERFLOW EXECUTE                                                | OP 1 NOT ON HALF-WORD BOUNDARY                                                                       |
|                                                                                                                   | Conc | dition Code | s                                    | EXPONENT OVERFLOW  EXPONENT UNDERFLOW                                   | OP 2 NOT ON HALF-WORD BOUNDARY OP 2 NOT ON FULL-WORD BOUNDARY OP 2 NOT ON DOUBLE-WORD                |
| ☐ IF RESULT = 0, SET TO 0 ☐ IF RESULT < 0, SET TO 1 ☐ IF RESULT > 0, SET TO 2 ☐ IF OVERFLOW, SET TO 3 ☐ UNCHANGED |      |             | ) 1<br>) 2                           | FIXED-POINT DIVIDE FIXED-POINT OVERFLOW FLOATING-POINT DIVIDE OPERATION | OP 2 NOT ON DOUBLE-WORD BOUNDARY OP 1 NOT EVEN NUMBERED REGISTER OP 1 NOT ODD NUMBERED REGISTER NONE |

#### Function:

Moves the contents of operand 2 to operand 1 with a 4-bit (half-byte) shift to the left.

## **Explicit Format:**

| LA   | BEL   | $\Delta$ operation $\Delta$ | OPERAND                                                                                           |
|------|-------|-----------------------------|---------------------------------------------------------------------------------------------------|
| [syn | [lodr | MVO                         | d <sub>1</sub> (l <sub>1</sub> ,b <sub>1</sub> ),d <sub>2</sub> (l <sub>2</sub> ,b <sub>2</sub> ) |

#### Implicit Format:

| LABEL    | $\Delta$ OPERATION $\Delta$ | OPERAND                                                           |
|----------|-----------------------------|-------------------------------------------------------------------|
| [symbol] | MVO                         | s <sub>1</sub> (I <sub>1</sub> ),s <sub>2</sub> (I <sub>2</sub> ) |
|          |                             |                                                                   |

- This instruction proceeds from right to left.
- The operands are not checked for valid codes.
- Overlapping fields may occur. Unless the operands overlap, operand 2 and the least significant four bits of operand 1 remain unchanged.
- If the second operand is exhausted before the first operand, the remaining first operand field is zero filled. If the result exceeds the capacity of the first operand field, the remaining digits of the second operand are ignored. This operation, in effect, prefixes the least significant digit or sign of the first operand with the digits of the second operand.

MVZ

PAGE

|                                                                                                                   |      | General        |                          | Possible                                                                | e Program Exceptions                                                                                 |
|-------------------------------------------------------------------------------------------------------------------|------|----------------|--------------------------|-------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------|
| орсо                                                                                                              | DE   | FORMAT<br>TYPE | OBJECT<br>INST.<br>LGTH. | ■ ADDRESSING □ DATA (INVALID SIGN/DIGIT)                                | PROTECTION SIGNIFICANCE                                                                              |
| MNEM.                                                                                                             | HEX. |                | (BYTES)                  | DECIMAL DIVIDE                                                          | SPECIFICATION:                                                                                       |
| MVZ                                                                                                               | D3   | SS             | 6                        | DECIMAL OVERFLOW EXECUTE                                                | OP 1 NOT ON HALF-WORD BOUNDARY                                                                       |
|                                                                                                                   | Conc | dition Code    | s                        | EXPONENT OVERFLOW  EXPONENT UNDERFLOW                                   | OP 2 NOT ON HALF-WORD BOUNDARY OP 2 NOT ON FULL-WORD BOUNDARY                                        |
| ☐ IF RESULT = 0, SET TO 0 ☐ IF RESULT < 0, SET TO 1 ☐ IF RESULT > 0, SET TO 2 ☐ IF OVERFLOW, SET TO 3 ☐ UNCHANGED |      |                | ) 1<br>) 2               | FIXED-POINT DIVIDE FIXED-POINT OVERFLOW FLOATING-POINT DIVIDE OPERATION | OP 2 NOT ON DOUBLE-WORD BOUNDARY OP 1 NOT EVEN NUMBERED REGISTER OP 1 NOT ODD NUMBERED REGISTER NONE |

#### Function:

Causes the most significant four bits (the zone field) of each byte specified by operand 2 to be moved to the most significant four bits of each byte of operand 1.

# **Explicit Format:**

| LABE  | L ∆ OPER | ATION $\Delta$                     | OPERAND                            |
|-------|----------|------------------------------------|------------------------------------|
| [symb | ool] MVZ | d <sub>1</sub> (l,b <sub>1</sub> ) | ),d <sub>2</sub> (b <sub>2</sub> ) |

#### Implicit Format:

| LABEL    | $\Delta$ OPERATION $\Delta$ | OPERAND                           |  |
|----------|-----------------------------|-----------------------------------|--|
| [symbol] | MVZ                         | s <sub>1</sub> (I),s <sub>2</sub> |  |

- The four least significant bits of each byte (digit field) remain unchanged.
- The contents of operand 2 remain unchanged unless there is overlapping.
- Overlapping of operands is permitted.
- The number of bytes transferred is specified by I in operand 1.
- If the number of bytes to be moved is not explicitly shown in operand 1, then the number will be equal to the length attribute of operand 1.

N

|       |                                                                                                                              | General        |                          | Possible                                                                | e Program Exceptions                                                                                 |
|-------|------------------------------------------------------------------------------------------------------------------------------|----------------|--------------------------|-------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------|
| орсо  | DE                                                                                                                           | FORMAT<br>TYPE | OBJECT<br>INST.<br>LGTH. | ■ ADDRESSING □ DATA (INVALID SIGN/DIGIT)                                | PROTECTION SIGNIFICANCE                                                                              |
| MNEM. | HEX.                                                                                                                         | 1172           | (BYTES)                  | DECIMAL DIVIDE                                                          | SPECIFICATION:                                                                                       |
| N     | 54                                                                                                                           | RX             | 4                        | ☐ EXECUTE                                                               | OP 1 NOT ON HALF-WORD BOUNDARY                                                                       |
|       | Conc                                                                                                                         | lition Code    | s                        | EXPONENT OVERFLOW  EXPONENT UNDERFLOW                                   | OP 2 NOT ON HALF-WORD BOUNDARY OP 2 NOT ON FULL-WORD BOUNDARY                                        |
| IF RE | Condition Codes  IF RESULT = 0, SET TO 0  IF RESULT ≠ 0, SET TO 1  IF RESULT > 0, SET TO 2  IF OVERFLOW, SET TO 3  UNCHANGED |                | ) 1<br>) 2               | FIXED-POINT DIVIDE FIXED-POINT OVERFLOW FLOATING-POINT DIVIDE OPERATION | OP 2 NOT ON DOUBLE-WORD BOUNDARY OP 1 NOT EVEN NUMBERED REGISTER OP 1 NOT ODD NUMBERED REGISTER NONE |

#### Function:

Causes a logical full-word AND operation to be performed on the contents of operand 1 (r<sub>1</sub>) and operand 2. The result is stored in the operand 1  $(r_1)$  register. Operand 2 is a full word in main storage.

# **Explicit Format:**

| LABEL    | $\Delta$ operation $\Delta$ | OPERAND                                                          |
|----------|-----------------------------|------------------------------------------------------------------|
| [symbol] | N                           | r <sub>1</sub> ,d <sub>2</sub> (x <sub>2</sub> ,b <sub>2</sub> ) |
|          |                             |                                                                  |

### Implicit Format:

| LABEL    | $\Delta$ OPERATION $\Delta$ | OPERAND                                          |
|----------|-----------------------------|--------------------------------------------------|
| [symbol] | N                           | r <sub>1</sub> ,s <sub>2</sub> (x <sub>2</sub> ) |
|          |                             |                                                  |

- If the corresponding bit positions in both operand 1 and operand 2 contain 1, the resultant bit will be 1. If either bit is zero, the resultant bit will be zero.
- The rules of operation for logical AND (N) are illustrated by the following truth table:

N

| Operand 1 | Operand 2 | Result<br>(Operand 1) |
|-----------|-----------|-----------------------|
| 0         | 0         | 0                     |
| 0         | 1         | 0                     |
| 1         | 0         | 0                     |
| 1         | 1         | 1                     |

- It is possible to clear selected bits in operand 1  $(r_1)$  by specifying zeros in the corresponding bit positions of operand 2.
- Operand 2 must be on a full-word boundary.

# NC

|                                                                                                            |                 | General        |                          | Possible                                                                | e Program Exceptions                                                                                 |  |
|------------------------------------------------------------------------------------------------------------|-----------------|----------------|--------------------------|-------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------|--|
| OPCODE                                                                                                     |                 | FORMAT<br>TYPE | OBJECT<br>INST.<br>LGTH. | ADDRESSING DATA (INVALID SIGN/DIGIT)                                    | PROTECTION SIGNIFICANCE                                                                              |  |
| MNEM.                                                                                                      | HEX.            |                | (BYTES)                  | DECIMAL DIVIDE                                                          | SPECIFICATION:                                                                                       |  |
| NC                                                                                                         | D4              | SS             | 6                        | DECIMAL OVERFLOW                                                        | OP 1 NOT ON HALF-WORD BOUNDARY                                                                       |  |
|                                                                                                            | Condition Codes |                |                          | EXPONENT OVERFLOW  EXPONENT UNDERFLOW                                   | OP 2 NOT ON HALF-WORD BOUNDARY OP 2 NOT ON FULL-WORD BOUNDARY OP 2 NOT ON DOUBLE-WORD                |  |
| IF RESULT = 0, SET TO 0  IF RESULT ≠0, SET TO 1  IF RESULT > 0, SET TO 2  IF OVERFLOW, SET TO 3  UNCHANGED |                 |                | ) 1<br>) 2               | FIXED-POINT DIVIDE FIXED-POINT OVERFLOW FLOATING-POINT DIVIDE OPERATION | OP 2 NOT ON DOUBLE-WORD BOUNDARY OP 1 NOT EVEN NUMBERED REGISTER OP 1 NOT ODD NUMBERED REGISTER NONE |  |

#### Function:

Causes a logical AND operation to be performed on the contents of operand 1 and operand 2. Both operands are located in main storage. The result is stored in operand 1.

### **Explicit Format:**

| LABEL    | $\Delta$ operation $\Delta$ | OPERAND                                                             |  |
|----------|-----------------------------|---------------------------------------------------------------------|--|
| [symbol] | NC                          | d <sub>1</sub> (I,b <sub>1</sub> ),d <sub>2</sub> (b <sub>2</sub> ) |  |

### Implicit Format:

| LABEL    | $\Delta$ OPERATION $\Delta$ | OPERAND                           |  |
|----------|-----------------------------|-----------------------------------|--|
| [symbol] | NC                          | s <sub>1</sub> (I),s <sub>2</sub> |  |

- If the corresponding bit positions in both operand 1 and operand 2 contain 1, the resultant bit will be 1. If either bit is zero, the resultant bit will be zero.
- The rules of operation for logical AND (NC) are illustrated by the following truth table:

NC

| Operand 1 | Operand 2 | Result<br>(Operand 1) |
|-----------|-----------|-----------------------|
| 0         | 0         | 0                     |
| 0         | 1         | 0                     |
| 1         | 0         | 0                     |
| 1         | 1         | 1                     |

- It is possible to clear selected bits in operand 1 by specifying zeros in the corresponding bit positions of operand 2.
- The number of bytes involved in the AND instruction is specified by I in operand 1.
- If the number of bytes to be used is not explicitly shown in operand 1, then the number will be equal to the length attribute of operand 1.

PAGE

| General |                                                                                                                  |                |                          | Possible                                                                | e Program Exceptions                                                                                 |  |
|---------|------------------------------------------------------------------------------------------------------------------|----------------|--------------------------|-------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------|--|
| OPCODE  |                                                                                                                  | FORMAT<br>TYPE | OBJECT<br>INST.<br>LGTH. | ADDRESSING DATA (INVALID SIGN/DIGIT)                                    | PROTECTION SIGNIFICANCE                                                                              |  |
| MNEM.   | MNEM. HEX. (BYTES)                                                                                               |                |                          | DECIMAL DIVIDE                                                          | SPECIFICATION:                                                                                       |  |
| NI      | 94                                                                                                               | SI             | 4                        | ☐ DECIMAL OVERFLOW                                                      | OP 1 NOT ON HALF-WORD BOUNDARY                                                                       |  |
|         | Condition Codes                                                                                                  |                |                          | EXPONENT OVERFLOW  EXPONENT UNDERFLOW                                   | OP 2 NOT ON HALF-WORD BOUNDARY OP 2 NOT ON FULL-WORD BOUNDARY OP 2 NOT ON DOUBLE-WORD                |  |
| ■ IF RE | IF RESULT = 0, SET TO 0  IF RESULT ≠0, SET TO 1  □ IF RESULT > 0, SET TO 2  □ IF OVERFLOW, SET TO 3  □ UNCHANGED |                |                          | FIXED-POINT DIVIDE FIXED-POINT OVERFLOW FLOATING-POINT DIVIDE OPERATION | OP 2 NOT ON DOUBLE-WORD BOUNDARY OP 1 NOT EVEN NUMBERED REGISTER OP 1 NOT ODD NUMBERED REGISTER NONE |  |

### Function:

Causes a logical AND operation to be performed on the contents of operand 1, a byte in main storage, and operand 2, a byte of immediate data in the instruction. The result is stored in operand 1.

### **Explicit Format:**

| LABEL    | $\Delta$ operation $\Delta$ | OPERAND                                         |   |
|----------|-----------------------------|-------------------------------------------------|---|
| [symbol] | NI                          | d <sub>1</sub> (b <sub>1</sub> ),i <sub>2</sub> | _ |

### Implicit Format:

| LABEL    | $\Delta$ OPERATION $\Delta$ |                                | OPERAND |  |
|----------|-----------------------------|--------------------------------|---------|--|
| [symbol] | NI                          | s <sub>1</sub> ,i <sub>2</sub> |         |  |

- If the corresponding bit positions in both operand 1 and operand 2 contain 1, the resultant bit will be
   If either bit is zero, the resultant bit will be zero.
- The rules of operation for logical AND (NI) are illustrated by the following truth table:

NI

PAGE

| Operand 1 | Operand 2 | Result<br>(Operand 1) |
|-----------|-----------|-----------------------|
| 0         | 0         | 0                     |
| 0         | 1         | 0                     |
| 1         | 0         | 0                     |
| 1         | 1         | 1                     |

It is possible to clear selected bits in operand 1 by specifying zeros in the corresponding bit positions of operand 2.

# NR

|                                                                                                       |                 | General        |                                     | Possible                                                                | e Program Exceptions                                                                          |
|-------------------------------------------------------------------------------------------------------|-----------------|----------------|-------------------------------------|-------------------------------------------------------------------------|-----------------------------------------------------------------------------------------------|
| OPCO<br>MNEM.                                                                                         | DE<br>HEX.      | FORMAT<br>TYPE | OBJECT<br>INST.<br>LGTH.<br>(BYTES) | ☐ ADDRESSING ☐ DATA (INVALID SIGN/DIGIT) ☐ DECIMAL DIVIDE               | ☐ PROTECTION ☐ SIGNIFICANCE ☐ SPECIFICATION:                                                  |
| NR                                                                                                    | 14              | RR             | 2                                   | DECIMAL OVERFLOW  EXECUTE                                               | NOT A FLOATING-POINT REGISTER  OP 1 NOT ON HALF-WORD BOUNDARY  OP 2 NOT ON HALF-WORD BOUNDARY |
|                                                                                                       | Condition Codes |                |                                     | EXPONENT OVERFLOW  EXPONENT UNDERFLOW  FIXED-POINT DIVIDE               | OP 2 NOT ON HALF-WORD BOUNDARY OP 2 NOT ON FULL-WORD BOUNDARY OP 2 NOT ON DOUBLE-WORD         |
| IF RESULT = 0, SET TO 0 IF RESULT ≠0, SET TO 1 IF RESULT >0, SET TO 2 IF OVERFLOW, SET TO 3 UNCHANGED |                 |                | ) 1<br>) 2                          | FIXED-POINT DIVIDE FIXED-POINT OVERFLOW FLOATING-POINT DIVIDE OPERATION | BOUNDARY  OP 1 NOT EVEN NUMBERED REGISTER  OP 1 NOT ODD NUMBERED REGISTER  NONE               |

#### Function:

Causes a logical AND operation to be performed on the contents of the registers specified by operand 1  $(r_1)$  and operand 2  $(r_2)$ . The result is stored in operand 1  $(r_1)$ .

### **Explicit and Implicit Format:**

| LABEL    | $\Delta$ OPERATION $\Delta$ | OPERAND                        |  |
|----------|-----------------------------|--------------------------------|--|
| [symbol] | NR                          | r <sub>1</sub> ,r <sub>2</sub> |  |

### **Operational Considerations:**

- If the corresponding bit positions in both operand 1 (r<sub>1</sub>) and operand 2 (r<sub>2</sub>) contain 1, the resultant bit will be 1. If either bit is zero, the resultant bit will be zero.
- The rules of operation for logical AND (NR) are illustrated by the following truth table:

| Operand 1 | Operand 2 | Result<br>(Operand 1) |
|-----------|-----------|-----------------------|
| 0         | 0         | 0                     |
| 0         | 1         | 0                     |
| 1         | 0         | 0                     |
| 1         | 1         | 1                     |

It is possible to clear selected bits in operand 1 by specifying zeros in the corresponding bit positions of operand 2.

0

|                                                                                                                 |      | General        |                                                                         | Possible Program Exceptions                                                                          |                                                               |  |
|-----------------------------------------------------------------------------------------------------------------|------|----------------|-------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------|---------------------------------------------------------------|--|
| OPCODE                                                                                                          |      | FORMAT<br>TYPE | OBJECT<br>INST.<br>LGTH.                                                | ■ ADDRESSING □ DATA (INVALID SIGN/DIGIT)                                                             |                                                               |  |
| MNEM.                                                                                                           | HEX. |                | (BYTES)                                                                 | DECIMAL DIVIDE                                                                                       | SPECIFICATION:                                                |  |
| G                                                                                                               | 56   | RX             | 4                                                                       | ☐ DECIMAL OVERFLOW ☐ EXECUTE                                                                         | NOT A FLOATING-POINT REGISTER  OP 1 NOT ON HALF-WORD BOUNDARY |  |
| Condition Codes                                                                                                 |      | s              | EXPONENT OVERFLOW  EXPONENT UNDERFLOW                                   | OP 2 NOT ON HALF-WORD BOUNDARY OP 2 NOT ON FULL-WORD BOUNDARY                                        |                                                               |  |
| IF RESULT = 0, SET TO 0  IF RESULT ≠0, SET TO 1  □ IF RESULT >0, SET TO 2  □ IF OVERFLOW, SET TO 3  □ UNCHANGED |      | ) 1<br>) 2     | FIXED-POINT DIVIDE FIXED-POINT OVERFLOW FLOATING-POINT DIVIDE OPERATION | OP 2 NOT ON DOUBLE-WORD BOUNDARY OP 1 NOT EVEN NUMBERED REGISTER OP 1 NOT ODD NUMBERED REGISTER NONE |                                                               |  |

### Function:

Causes a logical OR operation to be performed on the contents of operand 1  $(r_1)$  and operand 2, a full word in main storage. The result is stored in operand 1  $(r_1)$ .

#### **Explicit Format:**

| LABEL    | $\Delta$ OPERATION $\Delta$ | OPERAND                                                          |
|----------|-----------------------------|------------------------------------------------------------------|
| [symbol] | 0                           | r <sub>1</sub> ,d <sub>2</sub> (x <sub>2</sub> ,b <sub>2</sub> ) |
|          |                             |                                                                  |

### Implicit Format:

| LABEL    | △ OPERATION △ | OPERAND                                          |
|----------|---------------|--------------------------------------------------|
| [symbol] | 0             | r <sub>1</sub> ,s <sub>2</sub> (x <sub>2</sub> ) |

- A bit position in the result is set to 1 if the corresponding bit positions in either or both operands contain 1; otherwise, the result bit position is set to zero.
- The rules of operation for logical OR (O) are illustrated by the following truth table:

0

| Operand 1 | Operand 2 | Result<br>(Operand 1) |
|-----------|-----------|-----------------------|
| 0         | 0         | 0                     |
| 0         | 1         | 1                     |
| 1         | 0         | 1                     |
| 1         | 1         | 1                     |

Operand 2 must be on a full-word boundary.

OC

|        | ·                                                                                                               | General        |                          | Possible Program Exceptions                                             |                                                                                                      |
|--------|-----------------------------------------------------------------------------------------------------------------|----------------|--------------------------|-------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------|
| OPCODE |                                                                                                                 | FORMAT<br>TYPE | OBJECT<br>INST.<br>LGTH. | ■ ADDRESSING □ DATA (INVALID SIGN/DIGIT) □ DECIMAL DIVIDE               | PROTECTION SIGNIFICANCE SPECIFICATION:                                                               |
| MNEM.  | HEX.                                                                                                            |                | (BYTES)                  | DECIMAL OVERFLOW                                                        | NOT A FLOATING-POINT REGISTER                                                                        |
| oc     | D6                                                                                                              | SS             | 6                        | EXECUTE                                                                 | OP 1 NOT ON HALF-WORD BOUNDARY                                                                       |
|        | Condition Codes                                                                                                 |                |                          | EXPONENT OVERFLOW  EXPONENT UNDERFLOW                                   | OP 2 NOT ON HALF-WORD BOUNDARY OP 2 NOT ON FULL-WORD BOUNDARY OP 2 NOT ON DOUBLE-WORD                |
| IF RE  | ■ IF RESULT = 0, SET TO 0 ■ IF RESULT ≠0, SET TO 1 □ IF RESULT >0, SET TO 2 □ IF OVERFLOW, SET TO 3 □ UNCHANGED |                |                          | FIXED-POINT DIVIDE FIXED-POINT OVERFLOW FLOATING-POINT DIVIDE OPERATION | OP 2 NOT ON DOUBLE-WORD BOUNDARY OP 1 NOT EVEN NUMBERED REGISTER OP 1 NOT ODD NUMBERED REGISTER NONE |

# Function:

Causes a logical OR operation to be performed on the contents of main storage specified by operand 1 and operand 2. The result is stored in operand 1.

# **Explicit Format:**

| LABEL    | $\Delta$ OPERATION $\Delta$ | OPERAND                                                             |
|----------|-----------------------------|---------------------------------------------------------------------|
| [symbol] | ос                          | d <sub>1</sub> (I,b <sub>1</sub> ),d <sub>2</sub> (b <sub>2</sub> ) |

#### Implicit Format:

| LABEL    | $\Delta$ OPERATION $\Delta$ |                                   | OPERAND |  |
|----------|-----------------------------|-----------------------------------|---------|--|
| [symbol] | oc                          | s <sub>1</sub> (I),s <sub>2</sub> |         |  |

- A bit position in the result is set to 1 if the corresponding bit positions in either or both operands contain 1; otherwise, the result bit position is set to zero.
- The rules of operation for logical OR (OC) are illustrated by the following truth table:

OC

| Operand 1 | Operand 2 | Results<br>(Operand 1) |
|-----------|-----------|------------------------|
| 0         | 0         | 0                      |
| 0         | 1         | 1                      |
| 1         | 0         | 1                      |
| 1         | 1         | 1                      |

- The number of bytes used is specified by I in operand 1.
- If the number of bytes to be used is not explicitly shown in operand 1, then the number will be equal to the length attribute of operand 1.

PAGE

|       |                                                                                                       | General        |                                                          | Possible Program Exceptions                                 |                                                                                                      |
|-------|-------------------------------------------------------------------------------------------------------|----------------|----------------------------------------------------------|-------------------------------------------------------------|------------------------------------------------------------------------------------------------------|
| OPCO  | DE                                                                                                    | FORMAT<br>TYPE | OBJECT INST. LGTH.  ADDRESSING DATA (INVALID SIGN/DIGIT) |                                                             | PROTECTION SIGNIFICANCE                                                                              |
| MNEM. | HEX.                                                                                                  | ,,,,_          | (BYTES)                                                  | DECIMAL DIVIDE                                              | SPECIFICATION:                                                                                       |
| 01    | 96                                                                                                    | SI             | 4                                                        | ☐ DECIMAL OVERFLOW                                          | OP 1 NOT ON HALF-WORD BOUNDARY                                                                       |
|       | Condition Codes                                                                                       |                |                                                          | EXPONENT OVERFLOW  EXPONENT UNDERFLOW                       | OP 2 NOT ON HALF-WORD BOUNDARY OP 2 NOT ON FULL-WORD BOUNDARY                                        |
| IF RE | IF RESULT = 0, SET TO 0 IF RESULT ≠0, SET TO 1 IF RESULT >0, SET TO 2 IF OVERFLOW, SET TO 3 UNCHANGED |                |                                                          | FIXED-POINT DIVIDE FIXED-POINT OVERFLOW STORMSTON OPERATION | OP 2 NOT ON DOUBLE-WORD BOUNDARY OP 1 NOT EVEN NUMBERED REGISTER OP 1 NOT ODD NUMBERED REGISTER NONE |

#### Function:

Causes a logical OR operation to be performed on the contents of operand 1 (a byte in main storage) and operand 2 (a byte of immediate data in the instruction). The result is stored in operand 1.

# **Explicit Format:**

| LABEL    | $\Delta$ OPERATION $\Delta$ | OPERAND                                         |
|----------|-----------------------------|-------------------------------------------------|
| [symbol] | OI                          | d <sub>1</sub> (b <sub>1</sub> ),i <sub>2</sub> |
|          |                             |                                                 |

# Implicit Format:

| LABEL    | $\Delta$ OPERATION $\Delta$ |                                | OPERAND |
|----------|-----------------------------|--------------------------------|---------|
| [symbol] | OI                          | s <sub>1</sub> ,i <sub>2</sub> |         |
| •        |                             |                                |         |

# **Operational Considerations:**

A bit position in the result is set to 1 if the corresponding bit positions in either or both operands contain 1; otherwise, the result bit position is set to zero.

OI

■ The rules of operation for logical OR (OI) are illustrated by the following truth table:

| Operand 2 | Result<br>(Operand 1) |
|-----------|-----------------------|
| 0         | 0                     |
| 1         | 1                     |
| 0         | 1                     |
| 1         | 1                     |
|           | Operand 2  0 1 0 1    |

PAGE

|        |                                                                                                              | General        |            | Possible Program Exceptions                                                    |                                                                                                      |  |
|--------|--------------------------------------------------------------------------------------------------------------|----------------|------------|--------------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------|--|
| OPCODE |                                                                                                              | FORMAT<br>TYPE | INICT II U | ☐ ADDRESSING ☐ DATA (INVALID SIGN/DIGIT)                                       | ☐ PROTECTION ☐ SIGNIFICANCE                                                                          |  |
| MNEM.  | HEX.                                                                                                         |                | (BYTES)    | DECIMAL DIVIDE                                                                 | SPECIFICATION:                                                                                       |  |
| OR     | 16                                                                                                           | RR             | 2          | ☐ DECIMAL OVERFLOW ☐ EXECUTE                                                   | OP 1 NOT ON HALF-WORD BOUNDARY                                                                       |  |
|        | Condition Codes                                                                                              |                |            | EXPONENT OVERFLOW  EXPONENT UNDERFLOW                                          | OP 2 NOT ON HALF-WORD BOUNDARY OP 2 NOT ON FULL-WORD BOUNDARY OP 2 NOT ON DOUBLE-WORD                |  |
| IF RE  | IF RESULT = 0, SET TO 0 IF RESULT ≠0, SET TO 1 □ IF RESULT > 0, SET TO 2 □ IF OVERFLOW, SET TO 3 □ UNCHANGED |                |            | FIXED-POINT DIVIDE FIXED-POINT OVERFLOW STORMS FLOATING-POINT DIVIDE OPERATION | OP 2 NOT ON DOUBLE-WORD BOUNDARY OP 1 NOT EVEN NUMBERED REGISTER OP 1 NOT ODD NUMBERED REGISTER NONE |  |

#### Function:

Causes a logical OR operation to be performed on the contents of the registers specified by operand 1  $(r_1)$  and operand 2  $(r_2)$ . The result is stored in operand 1  $(r_1)$ .

# Explicit and Implicit Format:

| LABEL    | $\Delta$ OPERATION $\Delta$ | OPERAND                        |
|----------|-----------------------------|--------------------------------|
| [symbol] | OR                          | r <sub>1</sub> ,r <sub>2</sub> |

- A bit position in the result is set to 1 if the corresponding bit positions in either or both operands contain 1; otherwise, the result bit position is set to zero.
- The rules of operation for logical OR (OR) are illustrated by the following truth table:

| Operand 1 | Operand 2 | Result<br>(Operand 1) |
|-----------|-----------|-----------------------|
| 0         | 0         | 0                     |
| 0         | 1         | 1                     |
| 1         | 0         | 1                     |
| 1         | 1         | 1                     |

PAGE

#### General OBJECT ADDRESSIN OPCODE **FORMAT** INST. DATA (INVA TYPE LGTH. DECIMAL D (BYTES) MNEM. HEX DECIMAL O **PACK** F2 SS 6 ☐ EXECUTE

**Condition Codes** 

☐ IF RESULT = 0, SET TO 0

☐ IF RESULT < 0, SET TO 1

☐ IF RESULT > 0, SET TO 2 ☐ IF OVERFLOW, SET TO 3

| Possible Program Exceptions                    |                                                               |  |  |  |
|------------------------------------------------|---------------------------------------------------------------|--|--|--|
| ADDRESSING                                     | PROTECTION                                                    |  |  |  |
| DATA (INVALID SIGN/DIGIT) DECIMAL DIVIDE       | SIGNIFICANCE SPECIFICATION:                                   |  |  |  |
| DECIMAL OVERFLOW                               | NOT A FLOATING-POINT REGISTER                                 |  |  |  |
| EXECUTE  EXPONENT OVERFLOW                     | OP 1 NOT ON HALF-WORD BOUNDARY OP 2 NOT ON HALF-WORD BOUNDARY |  |  |  |
| EXPONENT UNDERFLOW                             | OP 2 NOT ON FULL-WORD BOUNDARY                                |  |  |  |
| FIXED-POINT DIVIDE                             | OP 2 NOT ON DOUBLE-WORD                                       |  |  |  |
| ☐ FIXED-POINT OVERFLOW ☐ FLOATING-POINT DIVIDE | BOUNDARY  OP 1 NOT EVEN NUMBERED REGISTER                     |  |  |  |
| OPERATION                                      | OP 1 NOT ODD NUMBERED REGISTER                                |  |  |  |

☐ NONE

# Function:

Converts the contents of operand 2 from the unpacked format to the packed format, which is placed in operand 1.

# **Explicit Format:**

UNCHANGED

| LABEL    | $\Delta$ OPERATION $\Delta$ | OPERAND                                                                                           |
|----------|-----------------------------|---------------------------------------------------------------------------------------------------|
| [symbol] | PACK                        | d <sub>1</sub> (l <sub>1</sub> ,b <sub>1</sub> ),d <sub>2</sub> (l <sub>2</sub> ,b <sub>2</sub> ) |

#### Implicit Format:

| LABEL    | $\Delta$ OPERATION $\Delta$ | OPERAND                                                           |
|----------|-----------------------------|-------------------------------------------------------------------|
| [symbol] | PACK ·                      | s <sub>1</sub> (I <sub>1</sub> ),s <sub>2</sub> (I <sub>2</sub> ) |

- This instruction proceeds one byte at a time from right to left. The first byte operated on has its sign and digit reversed. (An F4 becomes 4F.) Each byte from then on has its zone removed and the digit half of the byte packed into the receiving area.
- If operand 2 does not completely fill operand 1, the remaining operand 1 field is zero filled.
- If the result exceeds the capacity of the operand 1 field, the remaining operand 2 digits are ignored.
- The operands are not checked for valid codes.
- Overlapping fields may occur; each resultant byte is processed after each operand byte.

|       | General                                                                                                 |    |                          | Possible                                                                | e Program Exceptions                                                                                 |
|-------|---------------------------------------------------------------------------------------------------------|----|--------------------------|-------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------|
| орсо  | OPCODE FORMAT                                                                                           |    | OBJECT<br>INST.<br>LGTH. | ADDRESSING DATA (INVALID SIGN/DIGIT)                                    | PROTECTION SIGNIFICANCE                                                                              |
| MNEM. | HEX.                                                                                                    |    | (BYTES)                  | DECIMAL DIVIDE                                                          | SPECIFICATION:                                                                                       |
| S     | 58                                                                                                      | RX | 4                        | ☐ DECIMAL OVERFLOW ☐ EXECUTE                                            | OP 1 NOT ON HALF-WORD BOUNDARY                                                                       |
|       | Condition Codes                                                                                         |    |                          | EXPONENT OVERFLOW  EXPONENT UNDERFLOW                                   | OP 2 NOT ON HALF-WORD BOUNDARY OP 2 NOT ON FULL-WORD BOUNDARY OP 2 NOT ON DOUBLE-WORD                |
| IF RE | IF RESULT = 0, SET TO 0 IF RESULT < 0, SET TO 1 IF RESULT > 0, SET TO 2 IF OVERFLOW, SET TO 3 UNCHANGED |    |                          | FIXED-POINT DIVIDE FIXED-POINT OVERFLOW FLOATING-POINT DIVIDE OPERATION | OP 2 NOT ON DOUBLE-WORD BOUNDARY OP 1 NOT EVEN NUMBERED REGISTER OP 1 NOT ODD NUMBERED REGISTER NONE |

#### Function:

Causes the contents of operand 2, a full word in main storage, to be subtracted from the contents of the register specified by operand 1  $(r_1)$ . The results are placed in the operand 1  $(r_1)$  register.

#### **Explicit Format:**

| LABEL    | $\Delta$ OPERATION $\Delta$ | OPERAND            |
|----------|-----------------------------|--------------------|
| [symbol] | S                           | $r_1,d_2(x_2,b_2)$ |

#### Implicit Format:

| LABEL    | $\Delta$ OPERATION $\Delta$ | OPERAND                                          |
|----------|-----------------------------|--------------------------------------------------|
| [symbol] | S .                         | r <sub>1</sub> ,s <sub>2</sub> (x <sub>2</sub> ) |

- The subtraction is performed by converting the number in operand 2 into a signed twos complement binary number and then algebraically adding it to the value in operand 1  $(r_1)$ .
- The maximum fixed-point number that can be contained in a 32-bit register is 2,147,483,647(2³¹—1). The minimum number is —2,147,483,648(—2³¹). For decimal numbers outside this range, an overflow condition is produced.
- Operand 2 must be on a full-word boundary.
- The contents of operand 2 are not changed by the subtract (S) instruction.

# SD\*

#### Floating Point

|       | General                                                                                                           |           |                          | Possible Program Exceptions                                             |                                                                                                      |
|-------|-------------------------------------------------------------------------------------------------------------------|-----------|--------------------------|-------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------|
| орсо  | PCODE FORMAT                                                                                                      |           | OBJECT<br>INST.<br>LGTH. | ■ ADDRESSING □ DATA (INVALID SIGN/DIGIT)                                | PROTECTION SIGNIFICANCE                                                                              |
| MNEM. | HEX.                                                                                                              | , , , , _ | (BYTES)                  | DECIMAL DIVIDE                                                          | SPECIFICATION:                                                                                       |
| SD    | 6B                                                                                                                | RX        | 4                        | EXECUTE                                                                 | NOT A FLOATING-POINT REGISTER  OP 1 NOT ON HALF-WORD BOUNDARY                                        |
|       | Condition Codes                                                                                                   |           |                          | EXPONENT OVERFLOW  EXPONENT UNDERFLOW                                   | OP 2 NOT ON HALF-WORD BOUNDARY OP 2 NOT ON FULL-WORD BOUNDARY                                        |
| IF RE | ■ IF RESULT = 0, SET TO 0 ■ IF RESULT < 0, SET TO 1 ■ IF RESULT > 0, SET TO 2 □ IF OVERFLOW, SET TO 3 □ UNCHANGED |           |                          | FIXED-POINT DIVIDE FIXED-POINT OVERFLOW FLOATING-POINT DIVIDE OPERATION | OP 2 NOT ON DOUBLE-WORD BOUNDARY OP 1 NOT EVEN NUMBERED REGISTER OP 1 NOT ODD NUMBERED REGISTER NONE |

#### Function:

Causes the contents of a double word in main storage specified by operand 2 to be algebraically subtracted from the contents of the double word register specified by operand 1  $(r_1)$ . The normalized difference is placed in the operand 1  $(r_1)$  register.

#### **Explicit Format:**

| LABEL    | $\Delta$ OPERATION $\Delta$ | OPERAND                                                          |
|----------|-----------------------------|------------------------------------------------------------------|
| [symbol] | SD                          | r <sub>1</sub> ,d <sub>2</sub> (x <sub>2</sub> ,b <sub>2</sub> ) |

#### Implicit Format:

| LABEL    | $\Delta$ OPERATION $\Delta$ | OPERAND                                          |
|----------|-----------------------------|--------------------------------------------------|
| [symbol] | SD                          | r <sub>1</sub> ,s <sub>2</sub> (x <sub>2</sub> ) |

# Operational Consideration:

The execution of the SD instruction is identical to that of the AD instruction except that the sign of operand 2 is reversed before addition.

<sup>\*</sup> SD is a featured instruction. If you attempt to issue this instruction to a processor which does not have the control feature installed, you cause an operation program exception.

SDR\*

**Floating Point** 

| General                                                                                                           |                |                          | Possible Program Exceptions                                             |                                                                                                      |  |
|-------------------------------------------------------------------------------------------------------------------|----------------|--------------------------|-------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------|--|
| OPCODE                                                                                                            | FORMAT<br>TYPE | OBJECT<br>INST.<br>LGTH. | ☐ ADDRESSING ☐ DATA (INVALID SIGN/DIGIT)                                | PROTECTION SIGNIFICANCE                                                                              |  |
| MNEM. HEX.                                                                                                        | , , , , _      | (BYTES)                  | DECIMAL DIVIDE                                                          | SPECIFICATION:                                                                                       |  |
| SDR 2B                                                                                                            | RR             | 2                        | DECIMAL OVERFLOW  EXECUTE                                               | NOT A FLOATING-POINT REGISTER  OP 1 NOT ON HALF-WORD BOUNDARY                                        |  |
| Condition Codes                                                                                                   |                |                          | EXPONENT OVERFLOW  EXPONENT UNDERFLOW                                   | OP 2 NOT ON HALF-WORD BOUNDARY OP 2 NOT ON FULL-WORD BOUNDARY                                        |  |
| ■ IF RESULT = 0, SET TO 0 ■ IF RESULT < 0, SET TO 1 ■ IF RESULT > 0, SET TO 2 □ IF OVERFLOW, SET TO 3 □ UNCHANGED |                |                          | FIXED-POINT DIVIDE FIXED-POINT OVERFLOW FLOATING-POINT DIVIDE OPERATION | OP 2 NOT ON DOUBLE-WORD BOUNDARY OP 1 NOT EVEN NUMBERED REGISTER OP 1 NOT ODD NUMBERED REGISTER NONE |  |

#### Function:

Causes the contents of the double-word register specified by operand 2  $(r_2)$  to be algebraically subtracted from the contents of the double-word register specified by operand 1  $(r_1)$ . The normalized difference is placed in the operand 1  $(r_1)$  register.

#### **Explicit and Implicit Format:**

| LABEL    | $\Delta$ OPERATION $\Delta$ | OPERAND                        |  |  |
|----------|-----------------------------|--------------------------------|--|--|
| [symbol] | SDR                         | r <sub>1</sub> ,r <sub>2</sub> |  |  |

#### Operational Consideration:

■ The execution of the SDR instruction is identical to that of the ADR instruction, except that the sign of operand 2 (r₂) is reversed before addition.

SDR is a featured instruction. If you attempt to issue this instruction to a processor which does not have the control feature installed, you cause an operation program exception.

# SE\*

#### Floating Point

|        | General                                                                                                           |                |                          | Possible Program Exceptions                                             |                                                                                                      |
|--------|-------------------------------------------------------------------------------------------------------------------|----------------|--------------------------|-------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------|
| OPCODE |                                                                                                                   | FORMAT<br>TYPE | OBJECT<br>INST.<br>LGTH. | ADDRESSING DATA (INVALID SIGN/DIGIT)                                    | PROTECTION SIGNIFICANCE                                                                              |
| MNEM.  | нех.                                                                                                              |                | (BYTES)                  | DECIMAL DIVIDE                                                          | SPECIFICATION:                                                                                       |
| SE     | 7B                                                                                                                | RX             | 4                        | ☐ EXECUTE                                                               | NOT A FLOATING-POINT REGISTER  OP 1 NOT ON HALF-WORD BOUNDARY                                        |
|        | Condition Codes                                                                                                   |                |                          | EXPONENT OVERFLOW  EXPONENT UNDERFLOW                                   | OP 2 NOT ON HALF-WORD BOUNDARY OP 2 NOT ON FULL-WORD BOUNDARY OP 2 NOT ON DOUBLE-WORD                |
| IF RE  | ■ IF RESULT = 0, SET TO 0 ■ IF RESULT < 0, SET TO 1 ■ IF RESULT > 0, SET TO 2 □ IF OVERFLOW, SET TO 3 □ UNCHANGED |                |                          | FIXED-POINT DIVIDE FIXED-POINT OVERFLOW FLOATING-POINT DIVIDE OPERATION | OP 2 NOT ON DOUBLE-WORD BOUNDARY OP 1 NOT EVEN NUMBERED REGISTER OP 1 NOT ODD NUMBERED REGISTER NONE |

#### Function:

Causes the contents of a full word in main storage specified by operand 2 to be algebraically subtracted from a full word in the register specified by operand 1  $(r_1)$ . The normalized difference is placed in the operand 1  $(r_1)$  register.

# **Explicit Format:**

| LABEL    | $\Delta$ OPERATION $\Delta$ | OPERAND                                                          |
|----------|-----------------------------|------------------------------------------------------------------|
| [symbol] | SE                          | r <sub>1</sub> ,d <sub>2</sub> (x <sub>2</sub> ,b <sub>2</sub> ) |

# Implicit Format:

| LABEL    | $\Delta$ OPERATION $\Delta$ | OPERAND                                          |
|----------|-----------------------------|--------------------------------------------------|
| [symbol] | SE                          | r <sub>1</sub> ,s <sub>2</sub> (x <sub>2</sub> ) |

# Operational Consideration:

The execution of the SE instruction is identical to that of the AE instruction, except that the sign of operand 2 is reversed before addition.

SE is a featured instruction. If you attempt to issue this instruction to a processor which does not have the control feature installed, you cause an operation program exception.

SER\*

PAGE

Floating Point

|       |                                                                                                                   | General |         | Possible                                                                | e Program Exceptions                                                                                 |
|-------|-------------------------------------------------------------------------------------------------------------------|---------|---------|-------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------|
| орсо  | PCODE FORMAT INST.  TYPE LGTH.                                                                                    |         |         | ☐ ADDRESSING ☐ DATA (INVALID SIGN/DIGIT)                                | PROTECTION SIGNIFICANCE                                                                              |
| MNEM. | HEX.                                                                                                              |         | (BYTES) | DECIMAL DIVIDE                                                          | SPECIFICATION:                                                                                       |
| SER   | 3B                                                                                                                | RR      | 2       | DECIMAL OVERFLOW  EXECUTE                                               | NOT A FLOATING-POINT REGISTER  OP 1 NOT ON HALF-WORD BOUNDARY                                        |
|       | Condition Codes                                                                                                   |         |         | EXPONENT OVERFLOW  EXPONENT UNDERFLOW                                   | OP 2 NOT ON HALF-WORD BOUNDARY OP 2 NOT ON FULL-WORD BOUNDARY OP 2 NOT ON DOUBLE-WORD                |
| IF RE | ■ IF RESULT = 0, SET TO 0 ■ IF RESULT < 0, SET TO 1 ■ IF RESULT > 0, SET TO 2 □ IF OVERFLOW, SET TO 3 □ UNCHANGED |         |         | FIXED-POINT DIVIDE FIXED-POINT OVERFLOW FLOATING-POINT DIVIDE OPERATION | OP 2 NOT ON DOUBLE-WORD BOUNDARY OP 1 NOT EVEN NUMBERED REGISTER OP 1 NOT ODD NUMBERED REGISTER NONE |

# Function:

Causes the contents of a full word in the operand 2  $(r_2)$  register to be algebraically subtracted from a full word in the operand 1  $(r_1)$  register. The normalized difference is placed in a full word in the operand 1  $(r_1)$  register.

# **Explicit and Implicit Format:**

| LABEL    | $\Delta$ operation $\Delta$ | OPERAND                        |
|----------|-----------------------------|--------------------------------|
| [symbol] | SER                         | r <sub>1</sub> ,r <sub>2</sub> |

#### Operational Consideration:

■ The execution of the SER instruction is identical to that of the AER instruction, except that the sign of operand 2 is reversed before addition.

<sup>\*</sup> SER is a featured instruction. If you attempt to issue this instruction to a processor which does not have the control feature installed, you cause an operation program exception.

|       |                                                                                                                   | General                        |         | Possible                                                                | e Program Exceptions                                                                                 |
|-------|-------------------------------------------------------------------------------------------------------------------|--------------------------------|---------|-------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------|
| орсо  | DE                                                                                                                | OBJECT FORMAT INST. TYPE LGTH. |         | ADDRESSING DATA (INVALID SIGN/DIGIT)                                    | PROTECTION SIGNIFICANCE                                                                              |
| MNEM. | HEX.                                                                                                              |                                | (BYTES) | DECIMAL DIVIDE                                                          | SPECIFICATION:                                                                                       |
| SH    | 4B                                                                                                                | RX                             | 4       | ☐ EXECUTE                                                               | OP 1 NOT ON HALF-WORD BOUNDARY                                                                       |
|       | Condition Codes                                                                                                   |                                |         | EXPONENT OVERFLOW  EXPONENT UNDERFLOW                                   | OP 2 NOT ON HALF-WORD BOUNDARY OP 2 NOT ON FULL-WORD BOUNDARY OP 2 NOT ON DOUBLE-WORD                |
| IF RE | ■ IF RESULT = 0, SET TO 0 ■ IF RESULT < 0, SET TO 1 ■ IF RESULT > 0, SET TO 2 ■ IF OVERFLOW, SET TO 3 □ UNCHANGED |                                |         | FIXED-POINT DIVIDE FIXED-POINT OVERFLOW FLOATING-POINT DIVIDE OPERATION | OP 2 NOT ON DOUBLE-WORD BOUNDARY OP 1 NOT EVEN NUMBERED REGISTER OP 1 NOT ODD NUMBERED REGISTER NONE |

#### Function:

Causes the contents of operand 2, a half word in main storage, to be subtracted from the contents of the register specified by operand 1  $(r_1)$ . The results are to be placed in the operand 1  $(r_1)$  register.

# **Explicit Format:**

| LABEL    | $\Delta$ OPERATION $\Delta$ | OPERAND                                                          |
|----------|-----------------------------|------------------------------------------------------------------|
| [symbol] | SH                          | r <sub>1</sub> ,d <sub>2</sub> (x <sub>2</sub> ,b <sub>2</sub> ) |

#### Implicit Format:

| LABEL    | $\Delta$ OPERATION $\Delta$ | OPERAND                                          |
|----------|-----------------------------|--------------------------------------------------|
| [symbol] | SH                          | r <sub>1</sub> ,s <sub>2</sub> (x <sub>2</sub> ) |

- The subtraction is performed by converting the number in operand 2 into a signed twos complement binary number, expanded to a full word, and then algebraically adding it to the value in operand 1 (r<sub>1</sub>).
- The maximum fixed-point number that can be contained in 32-bit register is 2,147,483,647(2³¹—1); the minimum number is —2,147,483,648(—2³¹). For decimal numbers outside this range, an overflow condition is produced.
- Operand 2 must be on a half-word boundary.
- The contents of operand 2 are not changed by the subtract half word (SH) instruction.

UPDATE LEVEL

2-120a PAGE

SIO

|                 |                                               | General        |                          | Possible                                                                | e Program Exceptions                                                                                 |
|-----------------|-----------------------------------------------|----------------|--------------------------|-------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------|
| орсо            | DE                                            | FORMAT<br>TYPE | OBJECT<br>INST.<br>LGTH. | ☐ ADDRESSING ☐ DATA (INVALID SIGN/DIGIT)                                | ☐ PROTECTION ☐ SIGNIFICANCE                                                                          |
| MNEM.           | HEX.                                          | 1 1 1 1 1      | (BYTES)                  | DECIMAL DIVIDE                                                          | SPECIFICATION:                                                                                       |
| SIO             | 9C                                            | SI             | 4                        | DECIMAL OVERFLOW EXECUTE                                                | OP 1 NOT ON HALF-WORD BOUNDARY                                                                       |
| Condition Codes |                                               |                | s                        | EXPONENT OVERFLOW  EXPONENT UNDERFLOW                                   | OP 2 NOT ON HALF-WORD BOUNDARY OP 2 NOT ON FULL-WORD BOUNDARY OP 2 NOT ON DOUBLE-WORD                |
| SET T           | SET TO 0 SET TO 1 SET TO 2 SET TO 3 UNCHANGED |                |                          | FIXED-POINT DIVIDE FIXED-POINT OVERFLOW FLOATING-POINT DIVIDE OPERATION | OP 2 NOT ON DOUBLE-WORD BOUNDARY OP 1 NOT EVEN NUMBERED REGISTER OP 1 NOT ODD NUMBERED REGISTER NONE |

Function:

Initiates input and output operations to be executed by the 1/0 channels and the 1/0 status tabler.

**Explicit Format:** 

| LABEL    | $\triangle$ OPERATION $\triangle$ | OPERAND                          |
|----------|-----------------------------------|----------------------------------|
| [symbol] | SIO                               | d <sub>1</sub> (b <sub>1</sub> ) |

Implicit Format:

| LABEL    | $\Delta$ OPERATION $\Delta$ |                | OPERAND |
|----------|-----------------------------|----------------|---------|
| [symbol] | SIO .                       | s <sub>1</sub> |         |

SL\*

|                                                              |                     | General |         | Possible                                                                | e Program Exceptions                                                                                 |
|--------------------------------------------------------------|---------------------|---------|---------|-------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------|
| ОРСОЕ                                                        | OPCODE FORMAT INST. |         |         | ADDRESSING DATA (INVALID SIGN/DIGIT)                                    | PROTECTION SIGNIFICANCE                                                                              |
| MNEM.                                                        | HEX.                |         | (BYTES) | DECIMAL DIVIDE                                                          | SPECIFICATION:                                                                                       |
| SL                                                           | 5F                  | RX      | 4       | DECIMAL OVERFLOW EXECUTE                                                | OP 1 NOT ON HALF-WORD BOUNDARY                                                                       |
| Condition Codes                                              |                     |         | s       | EXPONENT OVERFLOW  EXPONENT UNDERFLOW                                   | OP 2 NOT ON HALF-WORD BOUNDARY OP 2 NOT ON FULL-WORD BOUNDARY                                        |
| SET TO 0 SET TO 1 SET TO 2 SET TO 3 SEE OPER. CONSIDERATIONS |                     |         |         | FIXED-POINT DIVIDE FIXED-POINT OVERFLOW FLOATING-POINT DIVIDE OPERATION | OP 2 NOT ON DOUBLE-WORD BOUNDARY OP 1 NOT EVEN NUMBERED REGISTER OP 1 NOT ODD NUMBERED REGISTER NONE |

# Function:

Causes the contents of a full word in main storage specified by operand 2 to be subtracted logically from the contents of the operand 1  $(r_1)$  register. The difference is placed in operand 1  $(r_1)$ .

#### **Explicit Format:**

| LABEL    | $\Delta$ OPERATION $\Delta$ | OPERAND                                                          |
|----------|-----------------------------|------------------------------------------------------------------|
| [symbol] | SL                          | r <sub>1</sub> ,d <sub>2</sub> (x <sub>2</sub> ,b <sub>2</sub> ) |

#### Implicit Format:

| LABEL    | $\Delta$ operation $\Delta$ | OPERAND                                          |
|----------|-----------------------------|--------------------------------------------------|
| [symbol] | SL                          | r <sub>1</sub> ,s <sub>2</sub> (x <sub>2</sub> ) |
| [symbol] | SL                          | r <sub>1</sub> ,s <sub>2</sub> (x <sub>2</sub> ) |

- The subtraction is performed by adding the twos complement of operand 2 to operand 1.
- All 32 bits of both operands are used.
- The contents of operand 2 remain unchanged.
- Operand 2 must be on a full-word boundary.

SL is a featured instruction. If you attempt to issue this instruction to a processor which does not have the control feature installed, you cause an operation program exception.

# SL

- The condition code is set:
  - to 1 if result is not zero (no carryout of most significant bit position);
  - to 2 if result is zero (carryout of most significant bit position); or
  - to 3 if result is not zero (carryout of most significant bit position).

Code 0 is not used. A zero difference cannot be obtained without a carryout of the most significant bit position.

SLA\*

PAGE

| General                                                                                                     |      |                |                          | Possible                                                                | e Program Exceptions                                                                                 |  |
|-------------------------------------------------------------------------------------------------------------|------|----------------|--------------------------|-------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------|--|
| OPCODE                                                                                                      |      | FORMAT<br>TYPE | OBJECT<br>INST.<br>LGTH. | ☐ ADDRESSING ☐ DATA (INVALID SIGN/DIGIT)                                | PROTECTION SIGNIFICANCE                                                                              |  |
| MNEM.                                                                                                       | HEX. |                | (BYTES)                  | DECIMAL DIVIDE                                                          | SPECIFICATION:  NOT A FLOATING-POINT REGISTER                                                        |  |
| SLA                                                                                                         | 8B   | RS             | 4                        | EXECUTE                                                                 | OP 1 NOT ON HALF-WORD BOUNDARY                                                                       |  |
| Condition Codes                                                                                             |      |                |                          | EXPONENT OVERFLOW  EXPONENT UNDERFLOW                                   | OP 2 NOT ON HALF-WORD BOUNDARY OP 2 NOT ON FULL-WORD BOUNDARY OP 2 NOT ON DOUBLE-WORD                |  |
| IF RESULT = 0, SET TO 0  IF RESULT < 0, SET TO 1  IF RESULT > 0, SET TO 2  IF OVERFLOW, SET TO 3  UNCHANGED |      |                |                          | FIXED-POINT DIVIDE FIXED-POINT OVERFLOW FLOATING-POINT DIVIDE OPERATION | OP 2 NOT ON DOUBLE-WORD BOUNDARY OP 1 NOT EVEN NUMBERED REGISTER OP 1 NOT ODD NUMBERED REGISTER NONE |  |

#### Function:

Causes the 31-bit integer field in the register specified by operand 1 ( $r_1$ ) to be shifted left the number of bit positions specified by the six low-order bits of the second operand ( $s_2$ ) address.

# **Explicit Format:**

| LABEL    | $\Delta$ OPERATION $\Delta$ | OPERAND                                          |  |  |
|----------|-----------------------------|--------------------------------------------------|--|--|
| [symbol] | SLA                         | r <sub>1</sub> ,d <sub>2</sub> (b <sub>2</sub> ) |  |  |

#### Implicit Format:

| LABEL    | $\Delta$ OPERATION $\Delta$ | OPERAND                        |
|----------|-----------------------------|--------------------------------|
| [symbol] | SLA                         | r <sub>1</sub> ,s <sub>2</sub> |

- The 31-bit integer of the first operand (r₁) is shifted left the number of bit positions specified by the low-order six bits of the second operand address.
- The vacated low-order bit positions of the register are zero filled. The sign bit of the register remains unchanged.
- If a bit unlike the sign bit is shifted out of the high-order numeric bit position, a fixed-point overflow condition exists.

<sup>\*</sup> SLA is a featured instruction. If you attempt to issue this instruction to a processor which does not have the control feature installed, you cause an operation program exception.

# SLA

- For numbers with an absolute value of less than 2<sup>30</sup>, a left shift of one bit position is equivalent to multiplying the number by 2.
- A shift of 31 bits causes the entire integer to be shifted out of the register. When the entire integer field for a positive number has been shifted out, the register contains a value of zero. For a negative number, the register contains a value of —2<sup>31</sup>.
- A zero shift value provides a sign and magnitude test.

SLDA\*

| General         |                       |                                                               |                          | Possible Program Exceptions                                             |                                                                                                       |  |
|-----------------|-----------------------|---------------------------------------------------------------|--------------------------|-------------------------------------------------------------------------|-------------------------------------------------------------------------------------------------------|--|
| OPCODE          |                       | FORMAT<br>TYPE                                                | OBJECT<br>INST.<br>LGTH. | ☐ ADDRESSING ☐ DATA (INVALID SIGN/DIGIT)                                | PROTECTION SIGNIFICANCE                                                                               |  |
| MNEM.           | HEX.                  | , , , , ,                                                     | (BYTES)                  | DECIMAL DIVIDE                                                          | SPECIFICATION:                                                                                        |  |
| SLDA            | 8F                    | RS                                                            | 4                        | DECIMAL OVERFLOW EXECUTE                                                | OP 1 NOT ON HALF-WORD BOUNDARY                                                                        |  |
| Condition Codes |                       |                                                               |                          | EXPONENT OVERFLOW  EXPONENT UNDERFLOW                                   | OP 2 NOT ON HALF-WORD BOUNDARY OP 2 NOT ON FULL-WORD BOUNDARY OP 2 NOT ON DOUBLE-WORD                 |  |
| IF RE           | SULT<br>SULT<br>/ERFL | = 0, SET TO<br>< 0, SET TO<br>> 0, SET TO<br>OW, SET TO<br>ED | ) 1<br>) 2               | FIXED-POINT DIVIDE FIXED-POINT OVERFLOW FLOATING-POINT DIVIDE OPERATION | OP 2 NOT ON DOUBLE-WORD BOUNDARY  OP 1 NOT EVEN NUMBERED REGISTER OP 1 NOT ODD NUMBERED REGISTER NONE |  |

#### Function:

Causes the 63-bit integer field in the pair of registers specified by operand 1  $(r_1)$  to be shifted left the number of bit positions specified by the six low-order bits of the second operand  $(s_2)$  address.

#### **Explicit Format:**

| LABEL    | $\Delta$ OPERATION $\Delta$ | OPERAND                                          |
|----------|-----------------------------|--------------------------------------------------|
| [symbol] | SLDA                        | r <sub>1</sub> ,d <sub>2</sub> (b <sub>2</sub> ) |

#### Implicit Format:

| LABEL    | $\Delta$ OPERATION $\Delta$ | OPERAND                        |
|----------|-----------------------------|--------------------------------|
| [symbol] | SLDA                        | r <sub>1</sub> ,s <sub>2</sub> |

- Operand 1 (r<sub>1</sub>) must refer to an even-numbered register of an even-odd register pair.
- The contents of both registers, except the sign bit of the even register, are shifted as one 63-bit integer. The vacated low-order bit positions of the odd register are zero filled. The sign bit of the even register remains unchanged.
- If a bit unlike the sign bit is shifted out of the high-order numeric bit position of the even register, a fixed-point overflow condition exists.

SLDA is a featured instruction. If you attempt to issue this instruction to a processor which does not have the control feature installed, you cause an operation program exception.

- A zero shift value in the double-shift operations provides a double-length sign and magnitude test.
- For numbers with an absolute value of less than 2<sup>30</sup>, a left shift of one bit position is equivalent to multiplying the number by 2.
- Shifting 63 bits causes the entire integer to be shifted out of the registers. When the entire integer field for a positive number has been shifted out, the register contains a value of zero. For a negative number, the register contains a value of —2<sup>31</sup>.

SLDL\*

|         |                                                                                                                        | General        |                                     | Possible                                                                                                     | e Program Exceptions                                                                                                                                               |
|---------|------------------------------------------------------------------------------------------------------------------------|----------------|-------------------------------------|--------------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| OPCO    |                                                                                                                        | FORMAT<br>TYPE | OBJECT<br>INST.<br>LGTH.<br>(BYTES) | ☐ ADDRESSING ☐ DATA (INVALID SIGN/DIGIT) ☐ DECIMAL DIVIDE                                                    | PROTECTION SIGNIFICANCE SPECIFICATION:                                                                                                                             |
| SLDL    | 8D                                                                                                                     | RS             | 4                                   | DECIMAL OVERFLOW                                                                                             | ☐ NOT A FLOATING-POINT REGISTER ☐ OP 1 NOT ON HALF-WORD BOUNDARY                                                                                                   |
| ☐ IF RE | Condition Codes    IF RESULT = 0, SET TO 0   IF RESULT < 0, SET TO 1   IF RESULT > 0, SET TO 2   IF OVERFLOW, SET TO 3 |                |                                     | EXPONENT OVERFLOW EXPONENT UNDERFLOW FIXED-POINT DIVIDE FIXED-POINT OVERFLOW FLOATING-POINT DIVIDE OPERATION | OP 2 NOT ON HALF-WORD BOUNDARY OP 2 NOT ON FULL-WORD BOUNDARY OP 2 NOT ON DOUBLE-WORD BOUNDARY OP 1 NOT EVEN NUMBERED REGISTER OP 1 NOT ODD NUMBERED REGISTER NONE |

# Function:

Causes the contents of the double word in the pair of registers specified by operand 1 ( $r_1$ ) to be shifted left the number of bit positions specified by the least significant six bits of the operand 2 address.

# **Explicit Format:**

| LABEL    | $\Delta$ OPERATION $\Delta$ | OPERAND                                          |  |  |
|----------|-----------------------------|--------------------------------------------------|--|--|
| [symbol] | SLDL                        | r <sub>1</sub> ,d <sub>2</sub> (b <sub>2</sub> ) |  |  |

# Implicit Format:

| LABEL    | $\Delta$ OPERATION $\Delta$ | OPERAND                        |
|----------|-----------------------------|--------------------------------|
| [symbol] | SLDL                        | r <sub>1</sub> ,s <sub>2</sub> |

- The vacated least significant bit positions of the registers are zero filled.
- Bits shifted out of the even-numbered register are lost.
- Operand 1 (r₁) must refer to the even-numbered register of an even-odd register pair.

<sup>\*</sup> SLDL is a featured instruction. If you attempt to issue this instruction to a processor which does not have the control feature installed, you cause an operation program exception.

| General                                                                                                           |      |                |                          | Possible Program Exceptions                                                   |                                                                                                      |  |
|-------------------------------------------------------------------------------------------------------------------|------|----------------|--------------------------|-------------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------|--|
| OPCODE                                                                                                            |      | FORMAT<br>TYPE | OBJECT<br>INST.<br>LGTH. | ☐ ADDRESSING ☐ DATA (INVALID SIGN/DIGIT)                                      | PROTECTION SIGNIFICANCE                                                                              |  |
| MNEM.                                                                                                             | HEX. |                | (BYTES)                  | DECIMAL DIVIDE                                                                | SPECIFICATION:                                                                                       |  |
| SLL                                                                                                               | 89   | RS             | 4                        | DECIMAL OVERFLOW EXECUTE                                                      | OP 1 NOT ON HALF-WORD BOUNDARY                                                                       |  |
| Condition Codes                                                                                                   |      |                |                          | EXPONENT OVERFLOW  EXPONENT UNDERFLOW                                         | OP 2 NOT ON HALF-WORD BOUNDARY OP 2 NOT ON FULL-WORD BOUNDARY OP 2 NOT ON DOUBLE-WORD                |  |
| ☐ IF RESULT = 0, SET TO 0 ☐ IF RESULT < 0, SET TO 1 ☐ IF RESULT > 0, SET TO 2 ☐ IF OVERFLOW, SET TO 3 ☐ UNCHANGED |      |                |                          | FIXED-POINT DIVIDE FIXED-POINT OVERFLOW STORM FLOATING-POINT DIVIDE OPERATION | OP 2 NOT ON DOUBLE-WORD BOUNDARY OP 1 NOT EVEN NUMBERED REGISTER OP 1 NOT ODD NUMBERED REGISTER NONE |  |

# Function:

Causes a full word in operand 1  $(r_1)$  to be shifted left the number of bit positions specified by the least significant six bits of the operand 2 address.

# **Explicit Format:**

| LABEL    | $\Delta$ OPERATION $\Delta$ |                                                  | OPERAND |  |
|----------|-----------------------------|--------------------------------------------------|---------|--|
| [symbol] | SLL                         | r <sub>1</sub> ,d <sub>2</sub> (b <sub>2</sub> ) |         |  |

# Implicit Format:

| LABEL    | $\Delta$ OPERATION $\Delta$ | OPERAND                        |
|----------|-----------------------------|--------------------------------|
| [symbol] | SLL                         | r <sub>1</sub> ,s <sub>2</sub> |

- The vacated least significant bit positions of the register are zero filled.
- Bits shifted out of the register are lost.

SLM

|        |                 | General                                                       |                          | Possible                                                                        | e Program Exceptions                                                                                 |
|--------|-----------------|---------------------------------------------------------------|--------------------------|---------------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------|
| OPCODE |                 | FORMAT<br>TYPE                                                | OBJECT<br>INST.<br>LGTH. | ■ ADDRESSING □ DATA (INVALID SIGN/DIGIT)                                        | PROTECTION SIGNIFICANCE                                                                              |
| MNEM.  | HEX.            | ,,,,_                                                         | (BYTES)                  | DECIMAL DIVIDE                                                                  | SPECIFICATION:                                                                                       |
| SLM    | B8              | RS                                                            | 4                        | DECIMAL OVERFLOW                                                                | OP 1 NOT ON HALF-WORD BOUNDARY                                                                       |
|        | Condition Codes |                                                               |                          | EXPONENT OVERFLOW  EXPONENT UNDERFLOW                                           | OP 2 NOT ON HALF-WORD BOUNDARY OP 2 NOT ON FULL-WORD BOUNDARY OP 2 NOT ON DOUBLE-WORD                |
| IF RE  | SULT<br>SULT    | = 0, SET TO<br>< 0, SET TO<br>> 0, SET TO<br>OW, SET TO<br>ED | ) 1<br>) 2               | ☐ FIXED-POINT DIVIDE ☐ FIXED-POINT OVERFLOW ☐ FLOATING-POINT DIVIDE ■ OPERATION | OP 2 NOT ON DOUBLE-WORD BOUNDARY OP 1 NOT EVEN NUMBERED REGISTER OP 1 NOT ODD NUMBERED REGISTER NONE |

# Function:

Causes the contents of operand 2, one or more full words in main storage, to be placed in the problem registers of operand 1  $(r_1)$  through operand 3  $(r_3)$ .

# **Explicit Format:**

| LABEL    | $\Delta$ OPERATION $\Delta$ | OPERAND                                                          |
|----------|-----------------------------|------------------------------------------------------------------|
| [symbol] | SLM                         | r <sub>1</sub> ,r <sub>3</sub> ,d <sub>2</sub> (b <sub>2</sub> ) |

# Implicit Format:

| LABEL    | $\Delta$ OPERATION $\Delta$ | OPERAND                                        |
|----------|-----------------------------|------------------------------------------------|
| [symbol] | SLM                         | r <sub>1</sub> ,r <sub>3</sub> ,s <sub>2</sub> |

|                                                                               |      | General                        |         | Possible                                                                                                          | e Program Exceptions                                                                                                                                               |  |
|-------------------------------------------------------------------------------|------|--------------------------------|---------|-------------------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|
| OPCODE                                                                        |      | OBJECT FORMAT INST. TYPE LGTH. |         |                                                                                                                   | PROTECTION SIGNIFICANCE                                                                                                                                            |  |
| MNEM.                                                                         | HEX. |                                | (BYTES) | DECIMAL DIVIDE                                                                                                    | SPECIFICATION:                                                                                                                                                     |  |
| SLR                                                                           | 1F   | RR                             | 2       | DECIMAL OVERFLOW EXECUTE                                                                                          | OP 1 NOT ON HALF-WORD BOUNDARY                                                                                                                                     |  |
| Condition Codes  SET TO 0 SET TO 1 SET TO 2 SET TO 3 SEE OPER, CONSIDERATIONS |      |                                |         | EXPONENT OVERFLOW  EXPONENT UNDERFLOW  FIXED-POINT DIVIDE  FIXED-POINT OVERFLOW  FLOATING-POINT DIVIDE  OPERATION | OP 2 NOT ON HALF-WORD BOUNDARY OP 2 NOT ON FULL-WORD BOUNDARY OP 2 NOT ON DOUBLE-WORD BOUNDARY OP 1 NOT EVEN NUMBERED REGISTER OP 1 NOT ODD NUMBERED REGISTER NONE |  |

#### Function:

Causes the contents of the operand 2  $(r_2)$  register to be subtracted logically from the contents of the operand 1  $(r_1)$  register. The difference is placed in operand 1  $(r_1)$ .

# Explicit and Implicit Format:

| LABEL    | $\Delta$ OPERATION $\Delta$ | OPERAND                        |
|----------|-----------------------------|--------------------------------|
| [symbol] | SLR                         | r <sub>1</sub> ,r <sub>2</sub> |

#### Operational Considerations:

- The subtraction is performed by adding the twos complement of operand 2 to operand 1.
- All 32 bits of both operands are used.
- The contents of operand 2 remain unchanged.
- The condition code is set:
  - to 1 if result is not zero (no carryout of most significant bit position);
  - to 2 if result is zero (carryout of most significant bit position); or
  - to 3 if result is not zero (carryout of most significant bit position).

Code 0 is not used. A zero difference cannot be obtained without a carryout of the most significant bit position.

SLR is a featured instruction. If you attempt to issue this instruction to a processor which does not have the control feature installed, you cause an operation program exception.

PAGE

|       |                                                                                                                   | General        |                          | Possible                                                                | e Program Exceptions                                                                                 |
|-------|-------------------------------------------------------------------------------------------------------------------|----------------|--------------------------|-------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------|
| OPCO  | DE                                                                                                                | FORMAT<br>TYPE | OBJECT<br>INST.<br>LGTH. | ■ ADDRESSING ■ DATA (INVALID SIGN/DIGIT)                                | PROTECTION SIGNIFICANCE                                                                              |
| MNEM. | HEX.                                                                                                              | , , , , _      | (BYTES)                  | DECIMAL DIVIDE                                                          | SPECIFICATION:                                                                                       |
| SP    | FB                                                                                                                | SS             | 6                        | ■ DECIMAL OVERFLOW □ EXECUTE                                            | OP 1 NOT ON HALF-WORD BOUNDARY                                                                       |
|       | Cond                                                                                                              | lition Code    | s                        | EXPONENT OVERFLOW  EXPONENT UNDERFLOW                                   | OP 2 NOT ON HALF-WORD BOUNDARY OP 2 NOT ON FULL-WORD BOUNDARY OP 2 NOT ON DOUBLE-WORD                |
| IF RE | ■ IF RESULT = 0, SET TO 0 ■ IF RESULT < 0, SET TO 1 ■ IF RESULT > 0, SET TO 2 ■ IF OVERFLOW, SET TO 3 □ UNCHANGED |                |                          | FIXED-POINT DIVIDE FIXED-POINT OVERFLOW FLOATING-POINT DIVIDE OPERATION | OP 2 NOT ON DOUBLE-WORD BOUNDARY OP 1 NOT EVEN NUMBERED REGISTER OP 1 NOT ODD NUMBERED REGISTER NONE |

#### Function:

Subtracts the contents of operand 2 from the contents of operand 1. The results are placed in operand 1.

# **Explicit Format:**

| _ | LABEL    | $\Delta$ operation $\Delta$ | OPERAND                                                                                           |
|---|----------|-----------------------------|---------------------------------------------------------------------------------------------------|
|   | [symbol] | SP                          | d <sub>1</sub> (l <sub>1</sub> ,b <sub>1</sub> ),d <sub>2</sub> (l <sub>2</sub> ,b <sub>2</sub> ) |

#### Implicit Format:

| LABEL    | $\Delta$ OPERATION $\Delta$ | OPERAND                                                           |
|----------|-----------------------------|-------------------------------------------------------------------|
| [symbol] | SP                          | s <sub>1</sub> (I <sub>1</sub> ),s <sub>2</sub> (I <sub>2</sub> ) |

- Subtraction is accomplished by reversing the sign of operand 2 and performing a decimal add. The contents and sign of operand 2 are not affected by this operation.
- All signs and digits are checked for validity and the sign of the result is determined algebraically.
- A zero result has a positive sign when the operation is completed without overflow.
- When most significant digits are lost because of overflow, the partial result has the sign that the correct result would have had.

SP

- If operand 2 is shorter than operand 1, operand 2 is extended with zero digits.
- An overflow condition results if the capacity of the operand 1 field is exceeded by the result or if the carryout of the most significant digit position of the result field is lost.
- Operand 1 and operand 2 may overlap if their least significant bytes coincide. Incorrect overlay will
  cause a data exception.

# **SPM**

|         |                                                              | General     |                          | Possible                                                                | e Program Exceptions                                                                                 |  |
|---------|--------------------------------------------------------------|-------------|--------------------------|-------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------|--|
| ОРСС    | DE                                                           | FORMAT      | OBJECT<br>INST.<br>LGTH. | ☐ ADDRESSING ☐ DATA (INVALID SIGN/DIGIT)                                | ☐ PROTECTION ☐ SIGNIFICANCE                                                                          |  |
| MNEM.   | HEX.                                                         | 1116        | (BYTES)                  | DECIMAL DIVIDE                                                          | SPECIFICATION:                                                                                       |  |
| SPM     | 04                                                           | RR          | 2                        | DECIMAL OVERFLOW EXECUTE                                                | OP 1 NOT ON HALF WORD BOUNDARY                                                                       |  |
|         | Cond                                                         | dition Code | s                        | EXPONENT OVERFLOW  EXPONENT UNDERFLOW                                   | OP 2 NOT ON HALF-WORD BOUNDARY OP 2 NOT ON FULL-WORD BOUNDARY                                        |  |
| SET SET | SET TO 0 SET TO 1 SET TO 2 SET TO 3 SEE OPER. CONSIDERATIONS |             |                          | FIXED-POINT DIVIDE FIXED-POINT OVERFLOW FLOATING-POINT DIVIDE OPERATION | OP 2 NOT ON DOUBLE-WORD BOUNDARY OP 1 NOT EVEN NUMBERED REGISTER OP 1 NOT ODD NUMBERED REGISTER NONE |  |

#### Function:

Causes the program mask field (bits 34 through 39) of the current program status word (PSW) to be changed according to the contents of operand 1  $(r_1)$ .

# **Explicit and Implicit Format:**

| LABEL    | $\Delta$ OPERATION $\Delta$ | OPERAND        |
|----------|-----------------------------|----------------|
| [symbol] | SPM                         | r <sub>1</sub> |

- Bits 2 through 7 of the full-word contents of operand 1 (r<sub>1</sub>) replace the program mask field (bits 34 through 39) of the current PSW.
- Bits 0, 1, and 8 through 31 of  $r_1$  are ignored.
- The condition code is set equal to bit positions 2 and 3 of operand 1.

SR

|                                                                                                         |                 | General        |                          | Possible                                                                | Program Exceptions                                                                                   |
|---------------------------------------------------------------------------------------------------------|-----------------|----------------|--------------------------|-------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------|
| OPCODE                                                                                                  |                 | FORMAT<br>TYPE | OBJECT<br>INST.<br>LGTH. |                                                                         | PROTECTION SIGNIFICANCE                                                                              |
| MNEM.                                                                                                   | HEX.            | ,,,_           | (BYTES)                  | DECIMAL DIVIDE                                                          | SPECIFICATION:                                                                                       |
| SR                                                                                                      | 1B              | RR             | 2                        | DECIMAL OVERFLOW EXECUTE                                                | OP 1 NOT ON HALF-WORD BOUNDARY                                                                       |
|                                                                                                         | Condition Codes |                |                          | EXPONENT OVERFLOW  EXPONENT UNDERFLOW                                   | OP 2 NOT ON HALF-WORD BOUNDARY OP 2 NOT ON FULL-WORD BOUNDARY OP 2 NOT ON DOUBLE-WORD                |
| IF RESULT = 0, SET TO 0 IF RESULT < 0, SET TO 1 IF RESULT > 0, SET TO 2 IF OVERFLOW, SET TO 3 UNCHANGED |                 |                | ) 1<br>) 2               | FIXED-POINT DIVIDE FIXED-POINT OVERFLOW FLOATING-POINT DIVIDE OPERATION | OP 2 NOT ON DOUBLE-WORD BOUNDARY OP 1 NOT EVEN NUMBERED REGISTER OP 1 NOT ODD NUMBERED REGISTER NONE |

#### Function:

Causes the contents of the operand 2  $(r_2)$  register to be subtracted from the contents of the operand 1  $(r_1)$  register. The results are placed in the operand 1  $(r_1)$  register.

#### **Explicit and Implicit Format:**

| LABEL    | $\Delta$ OPERATION $\Delta$ |                                | OPERAND | · · · · · · · · · · · · · · · · · · · |
|----------|-----------------------------|--------------------------------|---------|---------------------------------------|
| [symbol] | SR                          | r <sub>1</sub> ,r <sub>2</sub> |         |                                       |

- The subtraction is performed by converting the number in operand 2 (r₂) into a signed twos complement binary number and then algebraically adding it to the value in operand 1 (r₁).
- The maximum fixed-point number that can be contained in a 32-bit register is 2,147,483,647(2³¹—1); the minimum number is —2,147,483,648(—2³¹). For decimal numbers outside this range, an overflow condition is produced.
- lacktriangle The contents of operand 2 ( $r_2$ ) are not changed by the subtract (SR) instruction.

| General                                                                                                           |      |                |                          | Possible Program Exceptions                               |                                                                                       |  |
|-------------------------------------------------------------------------------------------------------------------|------|----------------|--------------------------|-----------------------------------------------------------|---------------------------------------------------------------------------------------|--|
| OPCODE                                                                                                            |      | FORMAT<br>TYPE | OBJECT<br>INST.<br>LGTH. | ☐ ADDRESSING ☐ DATA (INVALID SIGN/DIGIT)                  | PROTECTION SIGNIFICANCE                                                               |  |
| MNEM.                                                                                                             | HEX. |                | (BYTES)                  | DECIMAL DIVIDE                                            | SPECIFICATION:  NOT A FLOATING-POINT REGISTER                                         |  |
| SRA                                                                                                               | 8A   | RS             | 4                        | DECIMAL OVERFLOW  EXECUTE                                 | OP 1 NOT ON HALF-WORD BOUNDARY                                                        |  |
| Condition Codes                                                                                                   |      |                |                          | EXPONENT OVERFLOW  EXPONENT UNDERFLOW  FIXED-POINT DIVIDE | OP 2 NOT ON HALF-WORD BOUNDARY OP 2 NOT ON FULL-WORD BOUNDARY OP 2 NOT ON DOUBLE-WORD |  |
| ■ IF RESULT = 0, SET TO 0 ■ IF RESULT < 0, SET TO 1 ■ IF RESULT > 0, SET TO 2 □ IF OVERFLOW, SET TO 3 □ UNCHANGED |      |                |                          | FIXED-POINT OVERFLOW FLOATING-POINT DIVIDE OPERATION      | BOUNDARY  OP 1 NOT EVEN NUMBERED REGISTER  OP 1 NOT ODD NUMBERED REGISTER  NONE       |  |

#### Function:

Causes the 31-bit integer field in the register specified by operand 1  $(r_1)$  to be shifted right the number of bit positions specified by the six lower bits of the second operand  $(s_2)$  address.

# **Explicit Format:**

| LABEL    | $\Delta$ OPERATION $\Delta$ | OPERAND                                          |  |  |
|----------|-----------------------------|--------------------------------------------------|--|--|
| [symbol] | SRA                         | r <sub>1</sub> ,d <sub>2</sub> (b <sub>2</sub> ) |  |  |

#### Implicit Format:

| LABEL    | $\Delta$ OPERATION $\Delta$ | OPERAND                        |
|----------|-----------------------------|--------------------------------|
| [symbol] | SRA                         | r <sub>1</sub> ,s <sub>2</sub> |

- The 31-bit integer field of the first operand (r₁) is shifted right the number of bit positions specified by the low-order six bits of the second operand address. The sign bit remains unchanged.
- The bits shifted out of the low-order bit position of the register are lost; the vacated high-order bit positions of the register are sign filled.

<sup>\*</sup> SRA is a featured instruction. If you attempt to issue this instruction to a processor which does not have the control feature installed, you cause an operation program exception.

**SRA** 

- A right shift of one bit position is equivalent to division by 2 with rounding downward. When an even number is shifted right one position, the value of the field is that obtained by dividing the value by 2. When an odd number is shifted right one position, the value of the field is that obtained by dividing the next lower number by 2. For example, 5 shifted right by one bit position yields +2, whereas —5 yields —3.
- A shift of 31 bits causes the entire integer to be shifted out of the register. When the entire integer field of a positive number has been shifted out, the register contains a value of zero. For a negative number, the register contains a value of —1.
- A zero shift value provides a sign and magnitude test.

# SRDA\*

| General                                                                                                 |      |                |                          | Possible Program Exceptions                                             |                                                                                                      |  |
|---------------------------------------------------------------------------------------------------------|------|----------------|--------------------------|-------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------|--|
| OPCODE                                                                                                  |      | FORMAT<br>TYPE | OBJECT<br>INST.<br>LGTH. | ☐ ADDRESSING ☐ DATA (INVALID SIGN/DIGIT)                                | PROTECTION SIGNIFICANCE                                                                              |  |
| MNEM.                                                                                                   | HEX. | ,,,,           | (BYTES)                  | DECIMAL DIVIDE                                                          | SPECIFICATION:                                                                                       |  |
| SRDA                                                                                                    | 8E   | RS             | 4                        | ☐ EXECUTE                                                               | OP 1 NOT ON HALF-WORD BOUNDARY                                                                       |  |
| Condition Codes                                                                                         |      |                |                          | EXPONENT OVERFLOW  EXPONENT UNDERFLOW                                   | OP 2 NOT ON HALF-WORD BOUNDARY OP 2 NOT ON FULL-WORD BOUNDARY                                        |  |
| IF RESULT = 0, SET TO 0 IF RESULT < 0, SET TO 1 IF RESULT > 0, SET TO 2 IF OVERFLOW, SET TO 3 UNCHANGED |      |                |                          | FIXED-POINT DIVIDE FIXED-POINT OVERFLOW FLOATING-POINT DIVIDE OPERATION | OP 2 NOT ON DOUBLE-WORD BOUNDARY OP 1 NOT EVEN NUMBERED REGISTER OP 1 NOT ODD NUMBERED REGISTER NONE |  |

#### Function:

Causes the 63-bit integer field in the pair of registers specified by operand 1 (r<sub>1</sub>) to be shifted right the number of bit positions specified by the six low-order bits of the second operand (s<sub>2</sub>) address.

# **Explicit Format:**

| LABEL    | $\Delta$ operation $\Delta$ | OPERAND                                          |  |  |
|----------|-----------------------------|--------------------------------------------------|--|--|
| [symbol] | SRDA                        | r <sub>1</sub> ,d <sub>2</sub> (b <sub>2</sub> ) |  |  |

#### Implicit Format:

| LABEL    | $\Delta$ OPERATION $\Delta$ | OPERAND                        |  |
|----------|-----------------------------|--------------------------------|--|
| [symbol] | SRDA                        | r <sub>1</sub> ,s <sub>2</sub> |  |

- Operand 1 (r<sub>1</sub>) must refer to an even-numbered register of an even-odd register pair.
- The contents of both registers, except the sign bit of the even register, are shifted as one 63-bit integer. The bits shifted out of the low-order bit position of the odd register are lost; the vacated high-order bit positions of the register pair are sign filled.
- A right shift of one bit position is equivalent to dividing the number by 2, without a remainder.
- Shifting 63 bits causes the entire integer to be shifted out of the register. When the entire integer field for a positive number has been shifted out, the register contains a value of zero. For a negative number, the register contains a value of —1.
- A zero shift value in the double-shift operations provides a double-length sign and magnitude test.

<sup>\*</sup> SRDA is a featured instruction. If you attempt to issue this instruction to a processor which does not have the control feature installed, you cause an operation program exception.

SRDL\*

| General                                                                                                           |      |                |                          | Possible Program Exceptions                                             |                                                                                                      |  |
|-------------------------------------------------------------------------------------------------------------------|------|----------------|--------------------------|-------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------|--|
| OPCODE                                                                                                            |      | FORMAT<br>TYPE | OBJECT<br>INST.<br>LGTH. | ☐ ADDRESSING ☐ DATA (INVALID SIGN/DIGIT)                                | ☐ PROTECTION ☐ SIGNIFICANCE                                                                          |  |
| MNEM.                                                                                                             | HEX. | ,,,_           | (BYTES)                  | DECIMAL DIVIDE                                                          | SPECIFICATION:                                                                                       |  |
| SRDL                                                                                                              | 8C   | R\$            | 4                        | DECIMAL OVERFLOW EXECUTE                                                | ☐ NOT A FLOATING-POINT REGISTER ☐ OP 1 NOT ON HALF-WORD BOUNDARY                                     |  |
| Condition Codes                                                                                                   |      |                |                          | EXPONENT OVERFLOW  EXPONENT UNDERFLOW                                   | OP 2 NOT ON HALF-WORD BOUNDARY OP 2 NOT ON FULL-WORD BOUNDARY                                        |  |
| ☐ IF RESULT = 0, SET TO 0 ☐ IF RESULT < 0, SET TO 1 ☐ IF RESULT > 0, SET TO 2 ☐ IF OVERFLOW, SET TO 3 ☐ UNCHANGED |      |                |                          | FIXED-POINT DIVIDE FIXED-POINT OVERFLOW FLOATING-POINT DIVIDE OPERATION | OP 2 NOT ON DOUBLE-WORD BOUNDARY OP 1 NOT EVEN NUMBERED REGISTER OP 1 NOT ODD NUMBERED REGISTER NONE |  |

#### Function:

Causes the contents of the double word in the pair of registers specified by operand 1  $(r_1)$  to be shifted right the number of bit positions specified by the least significant six bits of the operand 2 address.

# **Explicit Format:**

| LABEL    | $\Delta$ OPERATION $\Delta$ | OPERAND                                          |  |  |  |
|----------|-----------------------------|--------------------------------------------------|--|--|--|
| [symbol] | SRDL                        | r <sub>1</sub> ,d <sub>2</sub> (b <sub>2</sub> ) |  |  |  |

#### Implicit Format:

| LABEL    | ABEL △ OPERATION △ |                                | OPERAND |
|----------|--------------------|--------------------------------|---------|
| [symbol] | SRDL               | r <sub>1</sub> ,s <sub>2</sub> |         |

- The vacated most significant bit positions of the registers are zero filled.
- Bits shifted out of the odd-numbered register are lost.
- Operand 1 (r<sub>1</sub>) must refer to the even-numbered register of an even-odd register pair.

<sup>\*</sup> SRDL is a featured instruction. If you attempt to issue this instruction to a processor which does not have the control feature installed, you cause an operation program exception.

# SRL

|       |      | General                                                       |                          | Possible                                                                | e Program Exceptions                                                                                 |
|-------|------|---------------------------------------------------------------|--------------------------|-------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------|
| ОРСС  | 1    | FORMAT<br>TYPE                                                | OBJECT<br>INST.<br>LGTH. | ☐ ADDRESSING ☐ DATA (INVALID SIGN/DIGIT) ☐ DECIMAL DIVIDE               | ☐ PROTECTION ☐ SIGNIFICANCE ☐ SPECIFICATION:                                                         |
| MNEM. | 1    |                                                               | (BYTES)                  | DECIMAL OVERFLOW                                                        | NOT A FLOATING-POINT REGISTER                                                                        |
| SRL   | 88   | RS                                                            | 4                        | ☐ EXECUTE ☐ EXPONENT OVERFLOW                                           | OP 1 NOT ON HALF-WORD BOUNDARY OP 2 NOT ON HALF-WORD BOUNDARY                                        |
|       | Cond | dition Code                                                   | :s                       | EXPONENT UNDERFLOW                                                      | OP 2 NOT ON FULL WORD BOUNDARY                                                                       |
| IF RE | SULT | = 0, SET TO<br>< 0, SET TO<br>> 0, SET TO<br>OW, SET TO<br>ED | ) 1<br>) 2               | FIXED-POINT DIVIDE FIXED-POINT OVERFLOW FLOATING-POINT DIVIDE OPERATION | OP 2 NOT ON DOUBLE-WORD BOUNDARY OP 1 NOT EVEN NUMBERED REGISTER OP 1 NOT ODD NUMBERED REGISTER NONE |

# Function:

Causes a full word in operand  $1(r_1)$  to be shifted right the number of bit positions specified by the least significant six bits of the operand 2 address.

# **Explicit Format:**

| LABEL    | $\Delta$ OPERATION $\Delta$ | OPERAND                                          |  |  |
|----------|-----------------------------|--------------------------------------------------|--|--|
| [symbol] | SRL                         | r <sub>1</sub> ,d <sub>2</sub> (b <sub>2</sub> ) |  |  |

# Implicit Format:

| LABEL    | $\Delta$ OPERATION $\Delta$ | OPERAND                        |
|----------|-----------------------------|--------------------------------|
| [symbol] | SRL                         | r <sub>1</sub> ,s <sub>2</sub> |

- The vacated most significant bit positions of the register are zero filled.
- Bits shifted out of the register are lost.

| General                                                                                               |      |                |                          | Possible Program Exceptions                                                     |                                                                                       |  |
|-------------------------------------------------------------------------------------------------------|------|----------------|--------------------------|---------------------------------------------------------------------------------|---------------------------------------------------------------------------------------|--|
| OPCODE                                                                                                |      | FORMAT<br>TYPE | OBJECT<br>INST.<br>LGTH. | ADDRESSING DATA (INVALID SIGN/DIGIT)                                            | PROTECTION SIGNIFICANCE                                                               |  |
| MNEM.                                                                                                 | HEX. |                | (BYTES)                  | DECIMAL DIVIDE                                                                  | SPECIFICATION:                                                                        |  |
| SSFS                                                                                                  | A2   | RS             | 4                        | DECIMAL OVERFLOW                                                                | NOT A FLOATING POINT REGISTER                                                         |  |
| 3373                                                                                                  |      | กง             |                          | ☐ EXECUTE                                                                       | OP 1 NOT ON HALF-WORD BOUNDARY                                                        |  |
| Condition Codes                                                                                       |      |                |                          | EXPONENT OVERFLOW  EXPONENT UNDERFLOW                                           | OP 2 NOT ON HALF-WORD BOUNDARY OP 2 NOT ON FULL-WORD BOUNDARY OP 2 NOT ON DOUBLE-WORD |  |
| ☐ IF RESULT = 0, SET TO 0 ☐ IF RESULT < 0, SET TO 1 ☐ IF RESULT > 0, SET TO 2 ☐ IF OVERFLOW, SET TO 3 |      |                |                          | ☐ FIXED-POINT DIVIDE ☐ FIXED-POINT OVERFLOW ☐ FLOATING-POINT DIVIDE ■ OPERATION | BOUNDARY  OP 1 NOT EVEN NUMBERED REGISTER  OP 1 NOT ODD NUMBERED REGISTER             |  |
| UNCHANGED                                                                                             |      |                |                          |                                                                                 | ☐ NONE                                                                                |  |

# Function:

Samples data at a specified rate after a sync pattern has been detected on the selected SOFTSCOPE data bus.

# Explicit and Implicit Format:

The bit pattern is the format of the instruction.

# **SSK**

| General                                                                                                           |      |                |                          | Possible Program Exceptions                                                                                       |                                                                                                                                                                    |  |
|-------------------------------------------------------------------------------------------------------------------|------|----------------|--------------------------|-------------------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|
| OPCODE                                                                                                            |      | FORMAT<br>TYPE | OBJECT<br>INST.<br>LGTH. | ■ ADDRESSING □ DATA (INVALID SIGN/DIGIT)                                                                          | I <del></del>                                                                                                                                                      |  |
| MNEM.                                                                                                             | HEX. |                | (BYTES)                  | DECIMAL DIVIDE                                                                                                    | ■ SPECIFICATION:  NOT A FLOATING-POINT REGISTER                                                                                                                    |  |
| SSK                                                                                                               | 08   | RR             | 2                        | EXECUTE                                                                                                           | OP 1 NOT ON HALF-WORD BOUNDARY                                                                                                                                     |  |
| Condition Codes                                                                                                   |      |                |                          | EXPONENT OVERFLOW  EXPONENT UNDERFLOW  FIXED-POINT DIVIDE  FIXED-POINT OVERFLOW  FLOATING-POINT DIVIDE  OPERATION | OP 2 NOT ON HALF-WORD BOUNDARY OP 2 NOT ON FULL-WORD BOUNDARY OP 2 NOT ON DOUBLE-WORD BOUNDARY OP 1 NOT EVEN NUMBERED REGISTER OP 1 NOT ODD NUMBERED REGISTER NONE |  |
| ☐ IF RESULT = 0, SET TO 0 ☐ IF RESULT < 0, SET TO 1 ☐ IF RESULT > 0, SET TO 2 ☐ IF OVERFLOW, SET TO 3 ☐ UNCHANGED |      |                |                          |                                                                                                                   |                                                                                                                                                                    |  |

# Function:

Specifies storage protection blocks of 512 bytes or 1024 bytes.

# Explicit and Implicit Format:

| LABEL    | $\Delta$ OPERATION $\Delta$ | OPERAND                         |  |
|----------|-----------------------------|---------------------------------|--|
| [symbol] | SSK                         | r <sub>1</sub> , r <sub>2</sub> |  |

UPDATE LEVEL

2-138c

SSM

|       |              | General                                                       |                          | Possible                                                                | e Program Exceptions                                                                                 |
|-------|--------------|---------------------------------------------------------------|--------------------------|-------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------|
| ОРСС  | DE           | FORMAT<br>TYPE                                                | OBJECT<br>INST.<br>LGTH. | ■ ADDRESSING □ DATA (INVALID SIGN/DIGIT)                                | PROTECTION SIGNIFICANCE                                                                              |
| MNEM. | HEX.         | ,,,,,                                                         | (BYTES)                  | DECIMAL DIVIDE                                                          | SPECIFICATION:                                                                                       |
| SSM   | 80           | SI                                                            | 4                        | DECIMAL OVERFLOW EXECUTE                                                | NOT A FLOATING-POINT REGISTER  OP 1 NOT ON HALF-WORD BOUNDARY                                        |
|       | Cond         | dition Code                                                   | s                        | EXPONENT OVERFLOW  EXPONENT UNDERFLOW                                   | OP 2 NOT ON HALF-WORD BOUNDARY OP 2 NOT ON FULL-WORD BOUNDARY                                        |
| IF RE | SULT<br>SULT | = 0, SET TO<br>< 0, SET TO<br>> 0, SET TO<br>OW, SET TO<br>ED | ) 1<br>) 2               | FIXED-POINT DIVIDE FIXED-POINT OVERFLOW FLOATING-POINT DIVIDE OPERATION | OP 2 NOT ON DOUBLE-WORD BOUNDARY OP 1 NOT EVEN NUMBERED REGISTER OP 1 NOT ODD NUMBERED REGISTER NONE |

## Function:

Causes the system mask of the current PSW to be replaced by the first half word of the first operand (bits 0—7).

## **Explicit Format:**

| LABEL    | $\Delta$ operation $\Delta$ | OPERAND                          |
|----------|-----------------------------|----------------------------------|
| [symbol] | SSM                         | d <sub>1</sub> (b <sub>1</sub> ) |

### Implicit Format:

| LABEL    | $\Delta$ OPERATION $\Delta$ | OPERAND        |
|----------|-----------------------------|----------------|
| [symbol] | SSM                         | s <sub>1</sub> |

# **SSRS**

|          | General                                                                                                 |                 |                |                          | Possible                                                                | e Program Exceptions                                                                                 |  |
|----------|---------------------------------------------------------------------------------------------------------|-----------------|----------------|--------------------------|-------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------|--|
| •        | ОРСО                                                                                                    | DE              | FORMAT<br>TYPE | OBJECT<br>INST.<br>LGTH. | ADDRESSING DATA (INVALID SIGN/DIGIT)                                    | PROTECTION SIGNIFICANCE                                                                              |  |
|          | MNEM.                                                                                                   | HEX.            |                | (BYTES)                  | DECIMAL DIVIDE                                                          | SPECIFICATION:                                                                                       |  |
|          | SSRS                                                                                                    | А3              | RS             | 4                        | DECIMAL OVERFLOW EXECUTE                                                | OP 1 NOT ON HALF WORD BOUNDARY                                                                       |  |
| <b>†</b> |                                                                                                         | Condition Codes |                |                          | EXPONENT OVERFLOW  EXPONENT UNDERFLOW                                   | OP 2 NOT ON HALF-WORD BOUNDAR OP 2 NOT ON FULL-WORD BOUNDAR                                          |  |
| •        | IF RESULT = 0, SET TO 0 IF RESULT < 0, SET TO 1 IF RESULT > 0, SET TO 2 IF OVERFLOW, SET TO 3 UNCHANGED |                 |                |                          | FIXED-POINT DIVIDE FIXED-POINT OVERFLOW FLOATING-POINT DIVIDE OPERATION | OP 2 NOT ON DOUBLE WORD BOUNDARY OP 1 NOT EVEN NUMBERED REGISTER OP 1 NOT ODD NUMBERED REGISTER NONE |  |

### Function:

Samples data at a specified rate, and stores the data into a revolving buffer until a sync pattern has been detected on the selected SOFTSCOPE data bus, or until the internal timer lapses.

## Explicit and Implicit Format:

The bit pattern is the format of the instruction.

# SSTN

|        |      | General                        |                          | Possible                                                                        | e Program Exceptions                                             |
|--------|------|--------------------------------|--------------------------|---------------------------------------------------------------------------------|------------------------------------------------------------------|
| OPCODE |      | FORMAT<br>TYPE                 | OBJECT<br>INST.<br>LGTH. | ADDRESSING DATA (INVALID SIGN/DIGIT)                                            | PROTECTION SIGNIFICANCE                                          |
| MNEM.  | HEX. | , , , , _                      | (BYTES)                  | DECIMAL DIVIDE                                                                  | SPECIFICATION:                                                   |
| SSTM   | ВО   | RS                             | Δ                        | DECIMAL OVERFLOW                                                                | NOT A FLOATING POINT REGISTER                                    |
|        |      | 110                            |                          | EXECUTE                                                                         | OP 1 NOT ON HALF-WORD BOUNDARY  OP 2 NOT ON HALF-WORD BOUNDARY   |
|        | Cond | dition Code                    | s                        | EXPONENT OVERFLOW  EXPONENT UNDERFLOW  FIXED-POINT DIVIDE  FIXED-POINT OVERFLOW | OP 2 NOT ON FULL-WORD BOUNDARY                                   |
|        |      | = 0, SET TO                    |                          |                                                                                 | OP 2 NOT ON DOUBLE-WORD BOUNDARY OP 1 NOT EVEN NUMBERED REGISTER |
| IF O   |      | >0, SET TO<br>OW, SET TO<br>ED |                          | FLOATING POINT DIVIDE OPERATION                                                 | OP 1 NOT ODD NUMBERED REGISTER NONE                              |

## Function:

Causes the contents of the registers specified by operand 1  $(r_1)$  through operand 3  $(r_3)$  to be stored in operand 2, one or more full words in main storage.

## **Explicit Format:**

| LABEL    | $\Delta$ OPERATION $\Delta$ | OPERAND                                                          |
|----------|-----------------------------|------------------------------------------------------------------|
| [symbol] | SSTM                        | r <sub>1</sub> ,r <sub>3</sub> ,d <sub>2</sub> (b <sub>2</sub> ) |

### Implicit Format:

| LABEL    | $\Delta$ OPERATION $\Delta$ | OPERAND                                        |
|----------|-----------------------------|------------------------------------------------|
| [symbol] | SSTM                        | r <sub>1</sub> ,r <sub>3</sub> ,s <sub>2</sub> |

|                                                                                                                   | ·               | General        |                                     | Possible                                                                | e Program Exceptions                                                                                 |
|-------------------------------------------------------------------------------------------------------------------|-----------------|----------------|-------------------------------------|-------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------|
| OPCC                                                                                                              |                 | FORMAT<br>TYPE | OBJECT<br>INST.<br>LGTH.<br>(BYTES) | ■ ADDRESSING □ DATA (INVALID SIGN/DIGIT) □ DECIMAL DIVIDE               | SPECIFICATION:                                                                                       |
| ST                                                                                                                | 50              | RX             | 4                                   | DECIMAL OVERFLOW EXECUTE                                                | OP 1 NOT ON HALF-WORD BOUNDARY                                                                       |
|                                                                                                                   | Condition Codes |                |                                     | EXPONENT OVERFLOW  EXPONENT UNDERFLOW                                   | OP 2 NOT ON HALF-WORD BOUNDARY OP 2 NOT ON FULL-WORD BOUNDARY                                        |
| ☐ IF RESULT = 0, SET TO 0 ☐ IF RESULT < 0, SET TO 1 ☐ IF RESULT > 0, SET TO 2 ☐ IF OVERFLOW, SET TO 3 ☐ UNCHANGED |                 |                |                                     | FIXED-POINT DIVIDE FIXED-POINT OVERFLOW FLOATING-POINT DIVIDE OPERATION | OP 2 NOT ON DOUBLE-WORD BOUNDARY OP 1 NOT EVEN NUMBERED REGISTER OP 1 NOT ODD NUMBERED REGISTER NONE |

### Function:

Causes the contents of the operand 1 (r<sub>1</sub>) register to be stored in operand 2, a full word in main storage.

### **Explicit Format:**

| LABEL    | $\Delta$ OPERATION $\Delta$ | OPERAND                                                          |
|----------|-----------------------------|------------------------------------------------------------------|
| [symbol] | ST                          | r <sub>1</sub> ,d <sub>2</sub> (x <sub>2</sub> ,b <sub>2</sub> ) |

## Implicit Format:

| LABEL    | $\Delta$ OPERATION $\Delta$ | OPERAND                                          |
|----------|-----------------------------|--------------------------------------------------|
| [symbol] | ST                          | r <sub>1</sub> ,s <sub>2</sub> (x <sub>2</sub> ) |
|          |                             |                                                  |

- The contents of the operand 1 (r₁) register are not changed by the *store* (ST) instruction.
- Operand 2, a full word in main storage, must be on a full-word boundary.
- Operand 1 is the sending field, operand 2 the receiving field.

|       |      | General                                                       |                          | Possible                                                                | e Program Exceptions                                                                                 |  |
|-------|------|---------------------------------------------------------------|--------------------------|-------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------|--|
| орсо  | DE   | FORMAT<br>TYPE                                                | OBJECT<br>INST.<br>LGTH, | DECIMAL DIVIDE                                                          | PROTECTION SIGNIFICANCE SPECIFICATION:                                                               |  |
| MNEM. | HEX. | –                                                             | (BYTES)                  |                                                                         |                                                                                                      |  |
| STC   | 42   | RX                                                            | 4                        | DECIMAL OVERFLOW EXECUTE                                                | NOT A FLOATING-POINT REGISTER  OP 1 NOT ON HALF-WORD BOUNDARY                                        |  |
|       | Cone | dition Code                                                   | S                        | EXPONENT OVERFLOW  EXPONENT UNDERFLOW                                   | OP 2 NOT ON HALF-WORD BOUNDARY OP 2 NOT ON FULL-WORD BOUNDARY OP 2 NOT ON DOUBLE-WORD                |  |
| IF RE | SULT | = 0, SET TO<br>< 0, SET TO<br>> 0, SET TO<br>OW, SET TO<br>ED | ) 1<br>) 2               | FIXED-POINT DIVIDE FIXED-POINT OVERFLOW FLOATING-POINT DIVIDE OPERATION | OP 2 NOT ON DOUBLE-WORD BOUNDARY OP 1 NOT EVEN NUMBERED REGISTER OP 1 NOT ODD NUMBERED REGISTER NONE |  |

### Function:

Causes the least significant eight bits of the operand 1  $(r_1)$  register to be stored in a byte of main storage specified by operand 2.

## **Explicit Format:**

| LABEL    | $\Delta$ OPERATION $\Delta$ | OPERAND                                                          |
|----------|-----------------------------|------------------------------------------------------------------|
| [symbol] | STC                         | r <sub>1</sub> ,d <sub>2</sub> (x <sub>2</sub> ,b <sub>2</sub> ) |

## Implicit Format:

| LABEL    | $\Delta$ OPERATION $\Delta$ | OPERAND                                          |
|----------|-----------------------------|--------------------------------------------------|
| [symbol] | STC                         | r <sub>1</sub> ,s <sub>2</sub> (x <sub>2</sub> ) |

## **Operational Considerations:**

■ The contents of operand 1 (r₁) remain unchanged.

STD\*

Floating Point

|       | General                                                                                                           |        |                          | Possible Program Exceptions                                                |                                                                                                      |  |
|-------|-------------------------------------------------------------------------------------------------------------------|--------|--------------------------|----------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------|--|
| ОРСС  | DE                                                                                                                | FORMAT | OBJECT<br>INST.<br>LGTH. | ADDRESSING DATA (INVALID SIGN/DIGIT)                                       | PROTECTION SIGNIFICANCE                                                                              |  |
| MNEM. | HEX.                                                                                                              |        | (BYTES)                  | DECIMAL DIVIDE                                                             | SPECIFICATION:                                                                                       |  |
| STD   | 60                                                                                                                | RX     | 4                        | DECIMAL OVERFLOW  EXECUTE                                                  | NOT A FLOATING-POINT REGISTER  OP 1 NOT ON HALF-WORD BOUNDARY                                        |  |
|       | Condition Codes                                                                                                   |        |                          | EXPONENT OVERFLOW  EXPONENT UNDERFLOW                                      | OP 2 NOT ON HALF-WORD BOUNDARY OP 2 NOT ON FULL-WORD BOUNDARY                                        |  |
| IF RE | ☐ IF RESULT = 0, SET TO 0 ☐ IF RESULT < 0, SET TO 1 ☐ IF RESULT > 0, SET TO 2 ☐ IF OVERFLOW, SET TO 3 ■ UNCHANGED |        |                          | FIXED-POINT DIVIDE  FIXED-POINT OVERFLOW  FLOATING-POINT DIVIDE  OPERATION | OP 2 NOT ON DOUBLE-WORD BOUNDARY OP 1 NOT EVEN NUMBERED REGISTER OP 1 NOT ODD NUMBERED REGISTER NONE |  |

### Function:

Causes the contents of the register specified by operand 1  $(r_1)$  to be placed in a double word in main storage specified by operand 2.

## **Explicit Format:**

| LABEL    | $\Delta$ operation $\Delta$ | OPERAND                                                          |
|----------|-----------------------------|------------------------------------------------------------------|
| [symbol] | STD                         | r <sub>1</sub> ,d <sub>2</sub> (x <sub>2</sub> ,b <sub>2</sub> ) |

### Implicit Format:

| LABEL    | $\Delta$ OPERATION $\Delta$ | OPERAND                                          |
|----------|-----------------------------|--------------------------------------------------|
| [symbol] | STD                         | r <sub>1</sub> ,s <sub>2</sub> (x <sub>2</sub> ) |

## **Operational Considerations:**

The contents of the operand 1 (r<sub>1</sub>) register remain unchanged.

STD is a featured instruction. If you attempt to issue this instruction to a processor which does not have the control feature installed, you cause an operation program exception.

### **Floating Point**

|                                                                                                                   |                 | General        |                          | Possible                                                                | e Program Exceptions                                                                                 |
|-------------------------------------------------------------------------------------------------------------------|-----------------|----------------|--------------------------|-------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------|
| орсс                                                                                                              | DE              | FORMAT<br>TYPE | OBJECT<br>INST.<br>LGTH. | ADDRESSING DATA (INVALID SIGN/DIGIT)                                    | PROTECTION SIGNIFICANCE                                                                              |
| MNEM.                                                                                                             | нех.            |                | (BYTES)                  | DECIMAL DIVIDE                                                          | SPECIFICATION:                                                                                       |
| STE                                                                                                               | 70              | RX             | 4                        | DECIMAL OVERFLOW  EXECUTE                                               | NOT A FLOATING-POINT REGISTER  OP 1 NOT ON HALF-WORD BOUNDARY                                        |
|                                                                                                                   | Condition Codes |                |                          | EXPONENT OVERFLOW  EXPONENT UNDERFLOW                                   | OP 2 NOT ON HALF-WORD BOUNDARY  OP 2 NOT ON FULL-WORD BOUNDARY  OP 2 NOT ON DOUBLE-WORD              |
| ☐ IF RESULT = 0, SET TO 0 ☐ IF RESULT < 0, SET TO 1 ☐ IF RESULT > 0, SET TO 2 ☐ IF OVERFLOW, SET TO 3 ☐ UNCHANGED |                 |                | ) 1<br>) 2               | FIXED-POINT DIVIDE FIXED-POINT OVERFLOW FLOATING-POINT DIVIDE OPERATION | OP 2 NOT ON DOUBLE-WORD BOUNDARY OP 1 NOT EVEN NUMBERED REGISTER OP 1 NOT ODD NUMBERED REGISTER NONE |

#### Function:

Causes the contents of a full word in the register specified by operand 1 (r<sub>1</sub>) to be placed in a full word in main storage specified by operand 2.

## **Explicit Format:**

| _ | LABEL    | $\Delta$ OPERATION $\Delta$ | OPERAND              |
|---|----------|-----------------------------|----------------------|
| - | [symbol] | STE                         | $r_1, d_2(x_2, b_2)$ |

## Implicit Format:

| LABEL    | $\Delta$ OPERATION $\Delta$ | OPERAND                                          |  |  |
|----------|-----------------------------|--------------------------------------------------|--|--|
| [symbol] | STE                         | r <sub>1</sub> ,s <sub>2</sub> (x <sub>2</sub> ) |  |  |

## **Operational Consideration:**

The contents of the operand  $1 (r_1)$  register remain unchanged.

STE is a featured instruction. If you attempt to issue this instruction to a processor which does not have the control feature installed, you cause an operation program exception.

| General |                                                                                                                   |                |                          | Possible Program Exceptions                                             |                                                                                 |  |
|---------|-------------------------------------------------------------------------------------------------------------------|----------------|--------------------------|-------------------------------------------------------------------------|---------------------------------------------------------------------------------|--|
| ОРСС    |                                                                                                                   | FORMAT<br>TYPE | OBJECT<br>INST.<br>LGTH. | ADDRESSING DATA (INVALID SIGN/DIGIT) DECIMAL DIVIDE                     | PROTECTION SIGNIFICANCE SPECIFICATION:                                          |  |
| MNEM.   | <del>                                     </del>                                                                  |                | (BYTES)                  | DECIMAL OVERFLOW                                                        | NOT A FLOATING-POINT REGISTER                                                   |  |
| STH     | 40                                                                                                                | RX             | 4                        | EXECUTE                                                                 | OP 1 NOT ON HALF-WORD BOUNDARY  OP 2 NOT ON HALF-WORD BOUNDARY                  |  |
|         | Condition Codes                                                                                                   |                |                          | EXPONENT OVERFLOW  EXPONENT UNDERFLOW  FIXED-POINT DIVIDE               | OP 2 NOT ON FULL-WORD BOUNDARY OP 2 NOT ON DOUBLE-WORD                          |  |
|         | ☐ IF RESULT = 0, SET TO 0 ☐ IF RESULT < 0, SET TO 1 ☐ IF RESULT > 0, SET TO 2 ☐ IF OVERFLOW, SET TO 3 ■ UNCHANGED |                |                          | FIXED-POINT DIVIDE FIXED-POINT OVERFLOW FLOATING-POINT DIVIDE OPERATION | BOUNDARY  OP 1 NOT EVEN NUMBERED REGISTER  OP 1 NOT ODD NUMBERED REGISTER  NONE |  |

### Function:

Causes the least significant 16 bits of the operand 1  $(r_1)$  register to be stored in operand 2, a half word in main storage.

## **Explicit Format:**

| LABEL    | $\Delta$ OPERATION $\Delta$ | OPERAND                                                          |
|----------|-----------------------------|------------------------------------------------------------------|
| [symbol] | STH                         | r <sub>1</sub> ,d <sub>2</sub> (x <sub>2</sub> ,b <sub>2</sub> ) |

#### Implicit Format:

| LABEL    | $\Delta$ OPERATION $\Delta$ | OPERAND                                          |
|----------|-----------------------------|--------------------------------------------------|
| [symbol] | STH .                       | r <sub>1</sub> ,s <sub>2</sub> (x <sub>2</sub> ) |

- The contents of the operand 1 (r<sub>1</sub>) register are not changed by the store half word (STH) instruction.
- Operand 2, a half word in main storage, must be on a half-word boundary.
- Operand 1 is the sending field, operand 2 the receiving field.

## STM

| ,     | General                                                                                                           |       |                         | Possible Program Exceptions                                                                |                                                                                                                                                                    |  |
|-------|-------------------------------------------------------------------------------------------------------------------|-------|-------------------------|--------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|
| ОРСО  | ODE FORMAT INST                                                                                                   |       | OBJECT<br>INST<br>LGTH. | ■ ADDRESSING □ DATA (INVALID SIGN/DIGIT)                                                   | PROTECTION SIGNIFICANCE                                                                                                                                            |  |
| MNEM. | HEX.                                                                                                              | , , , | (BYTES)                 | DECIMAL DIVIDE                                                                             | SPECIFICATION:                                                                                                                                                     |  |
| STM   | 90                                                                                                                | RS    | 4                       | DECIMAL OVERFLOW EXECUTE                                                                   | OP 1 NOT ON HALF-WORD BOUNDARY                                                                                                                                     |  |
|       | Condition Codes                                                                                                   |       |                         | EXPONENT UNDERFLOW FIXED-POINT DIVIDE FIXED-POINT OVERFLOW FLOATING-POINT DIVIDE OPERATION | OP 2 NOT ON HALF-WORD BOUNDARY OP 2 NOT ON FULL-WORD BOUNDARY OP 2 NOT ON DOUBLE-WORD BOUNDARY OP 1 NOT EVEN NUMBERED REGISTER OP 1 NOT ODD NUMBERED REGISTER NONE |  |
| IF RE | ☐ IF RESULT = 0, SET TO 0 ☐ IF RESULT < 0, SET TO 1 ☐ IF RESULT > 0, SET TO 2 ☐ IF OVERFLOW, SET TO 3 ☐ UNCHANGED |       |                         |                                                                                            |                                                                                                                                                                    |  |

#### Function:

Causes the contents of the registers specified by operand 1  $(r_1)$  through operand 3  $(r_3)$  to be stored in operand 2, one or more full words in main storage.

#### **Explicit Format:**

| LABEL    | $\Delta$ OPERATION $\Delta$ | OPERAND                                                          |
|----------|-----------------------------|------------------------------------------------------------------|
| [symbol] | STM                         | r <sub>1</sub> ,r <sub>3</sub> ,d <sub>2</sub> (b <sub>2</sub> ) |

#### Implicit Format:

| LABEL    | $\Delta$ OPERATION $\Delta$ | OPEF                                           | IAND |
|----------|-----------------------------|------------------------------------------------|------|
| [symbol] | STM                         | r <sub>1</sub> ,r <sub>3</sub> ,s <sub>2</sub> |      |

- The contents of the general registers starting with the register specified by operand 1 (r₁) and ending with the register specified by operand 3 (r₃) are stored in one or more full words in main storage beginning with the address specified by operand 2 (s₂).
- The registers are used in ascending numeric sequence beginning with the register specified by operand 1  $(r_1)$  and continuing through the register specified by operand 3  $(r_3)$ .
- One register may be stored by specifying the same register for both operand 1 (r<sub>1</sub>) and operand 3 (r<sub>3</sub>).

**STM** 

PAGE

- If the register specified by operand 3 (r<sub>3</sub>) is lower than the register specified by operand 1 (r<sub>1</sub>) then the register specified by operand 1 (r<sub>1</sub>) and all registers with a number greater than operand 1 (r<sub>1</sub>), plus the register specified by operand 3 (r<sub>3</sub>) and all registers with a number less than operand 3 (r<sub>3</sub>), are stored.
- The contents of all registers used remain unchanged.
- Operand 2 (s<sub>2</sub>) must be on a full-word boundary.

# **STR**

|       |                                                                                                         | General        |                          | Possible                                                                       | e Program Exceptions                                                                                 |
|-------|---------------------------------------------------------------------------------------------------------|----------------|--------------------------|--------------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------|
| ОРСО  | DE                                                                                                      | FORMAT<br>TYPE | OBJECT<br>INST.<br>LGTH. | ☐ ADDRESSING ☐ DATA (INVALID SIGN/DIGIT)                                       | PROTECTION SIGNIFICANCE                                                                              |
| MNEM. | HEX.                                                                                                    | 1112           | (BYTES)                  | DECIMAL DIVIDE                                                                 | SPECIFICATION:                                                                                       |
| STR   | 03                                                                                                      | RR             | 2                        | DECIMAL OVERFLOW                                                               | OP 1 NOT ON HALF-WORD BOUNDARY                                                                       |
|       | Condition Codes                                                                                         |                |                          | EXPONENT OVERFLOW  EXPONENT UNDERFLOW                                          | OP 2 NOT ON HALF-WORD BOUNDARY OP 2 NOT ON FULL-WORD BOUNDARY                                        |
| IF RE | IF RESULT = 0, SET TO 0 IF RESULT < 0, SET TO 1 IF RESULT > 0, SET TO 2 IF OVERFLOW, SET TO 3 UNCHANGED |                | ) 1<br>) 2               | FIXED-POINT DIVIDE FIXED-POINT OVERFLOW STORMS FLOATING-POINT DIVIDE OPERATION | OP 2 NOT ON DOUBLE-WORD BOUNDARY OP 1 NOT EVEN NUMBERED REGISTER OP 1 NOT ODD NUMBERED REGISTER NONE |

Function:

Controls internal timer register.

Explicit and Implicit Format:

| LABEL    | $\Delta$ OPERATION $\Delta$ | OPERAND                         |
|----------|-----------------------------|---------------------------------|
| [symbol] | STR                         | r <sub>1</sub> , r <sub>2</sub> |

SU\*

Floating Point



#### Function:

Causes the contents of a full word in main storage specified by operand 2 to be algebraically subtracted from the contents of a full word in the register specified by operand  $1(r_1)$ . The difference is placed in a full word in the operand  $1(r_1)$  register.

#### **Explicit Format:**

| LABEL    | $\Delta$ operation $\Delta$ | OPERAND                                                          |
|----------|-----------------------------|------------------------------------------------------------------|
| [symbol] | SU                          | r <sub>1</sub> ,d <sub>2</sub> (x <sub>2</sub> ,b <sub>2</sub> ) |

#### Implicit Format:

| LABEL    | $\Delta$ OPERATION $\Delta$ | OPERAND                                          |
|----------|-----------------------------|--------------------------------------------------|
| [symbol] | SU                          | r <sub>1</sub> ,s <sub>2</sub> (x <sub>2</sub> ) |

### Operational Consideration:

The execution of the SU instruction is identical to that of the AU instruction, except that the sign is reversed before addition.

<sup>\*</sup> SU is a featured instruction. If you attempt to issue this instruction to a processor which does not have the control feature installed, you cause an operation program exception.

|  |  | · · · · · · · · · · · · · · · · · · · |
|--|--|---------------------------------------|

SUR\*

Floating Point

| General |                                                                                                             |                |                          | Possible Program Exceptions                                             |                                                                                                      |  |
|---------|-------------------------------------------------------------------------------------------------------------|----------------|--------------------------|-------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------|--|
| OPCODE  |                                                                                                             | FORMAT<br>TYPE | OBJECT<br>INST.<br>LGTH. | ☐ ADDRESSING ☐ DATA (INVALID SIGN/DIGIT)                                | PROTECTION SIGNIFICANCE                                                                              |  |
| MNEM.   | нех.                                                                                                        | , , , ,        | (BYTES)                  | DECIMAL DIVIDE                                                          | SPECIFICATION:                                                                                       |  |
| SUR     | 3F                                                                                                          | RR             | 2                        | DECIMAL OVERFLOW EXECUTE                                                | NOT A FLOATING-POINT REGISTER  OP 1 NOT ON HALF-WORD BOUNDARY                                        |  |
|         | Condition Codes                                                                                             |                |                          | EXPONENT OVERFLOW  EXPONENT UNDERFLOW                                   | OP 2 NOT ON HALF-WORD BOUNDARY OP 2 NOT ON FULL-WORD BOUNDARY OP 2 NOT ON DOUBLE-WORD                |  |
| IF RE   | IF RESULT = 0, SET TO 0  IF RESULT < 0, SET TO 1  IF RESULT > 0, SET TO 2  IF OVERFLOW, SET TO 3  UNCHANGED |                |                          | FIXED-POINT DIVIDE FIXED-POINT OVERFLOW FLOATING-POINT DIVIDE OPERATION | OP 2 NOT ON DOUBLE-WORD BOUNDARY OP 1 NOT EVEN NUMBERED REGISTER OP 1 NOT ODD NUMBERED REGISTER NONE |  |

#### Function:

Causes the contents of a full word in the operand 2  $(r_2)$  register to be algebraically subtracted from a full word in the operand 1  $(r_1)$  register. The difference is placed in a full word in the operand 1  $(r_1)$  register.

## **Explicit and Implicit Format:**

| LABEL    | $\Delta$ OPERATION $\Delta$ | OPERAND                        |
|----------|-----------------------------|--------------------------------|
| [symbol] | SUR                         | r <sub>1</sub> ,r <sub>2</sub> |

### Operational Considerations:

■ The execution of the SUR instruction is identical to that of the AUR instruction, except that the sign is reversed before addition.

<sup>\*</sup> SUR is a featured instruction. If you attempt to issue this instruction to a processor which does not have the control feature installed, you cause an operation program exception.

## SVC

|                       | _                                                                                                                              | General        |                   | Possible                                                                | e Program Exceptions                                                                                 |
|-----------------------|--------------------------------------------------------------------------------------------------------------------------------|----------------|-------------------|-------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------|
| орсо                  | DE                                                                                                                             | FORMAT<br>TYPE | OBJECT<br>INST.   | ☐ ADDRESSING ☐ DATA (INVALID SIGN/DIGIT)                                | ☐ PROTECTION ☐ SIGNIFICANCE                                                                          |
| MNEM.                 | HEX,                                                                                                                           | 1114           | (BYTES)           | DECIMAL DIVIDE                                                          | SPECIFICATION:                                                                                       |
| SVC                   | 0A                                                                                                                             | RR             | 2                 | DECIMAL OVERFLOW EXECUTE                                                | OP 1 NOT ON HALF-WORD BOUNDARY                                                                       |
|                       | Condition Codes                                                                                                                |                |                   | EXPONENT OVERFLOW  EXPONENT UNDERFLOW                                   | OP 2 NOT ON HALF-WORD BOUNDARY OP 2 NOT ON FULL-WORD BOUNDARY OP 2 NOT ON DOUBLE-WORD                |
| #FRE<br>#FRE<br>■IFOV | ■ IF RESULT = 0, SET TO 0 ■ IF RESULT < 0, SET TO 1 ■ IF RESULT > 0, SET TO 2 ■ IF OVERFLOW, SET TO 3 SEE OPER. CONSIDERATIONS |                | ) 1<br>) 2<br>) 3 | FIXED-POINT DIVIDE FIXED-POINT OVERFLOW FLOATING-POINT DIVIDE OPERATION | OP 2 NOT ON DOUBLE-WORD BOUNDARY OP 1 NOT EVEN NUMBERED REGISTER OP 1 NOT ODD NUMBERED REGISTER NONE |

#### Function:

Causes the interrupt code field (bits 24 through 31) of the current program status word (PSW) to be changed according to the contents of operand 1, a byte of immediate data in the instruction.

## Explicit and Implicit Format:

| LABEL    | $\Delta$ OPERATION $\Delta$ | OPERAND        |
|----------|-----------------------------|----------------|
| [symbol] | svc                         | i <sub>1</sub> |

- A supervisor call interrupt request is generated.
- When the interrupt is granted, the contents of operand 1 (i<sub>1</sub>) are stored as the interrupt code (bits 24 through 31) in the current program status word (PSW). The current PSW is stored in the supervisor call old PSW location, and the contents of the supervisor call new PSW location replace the current PSW.
- The condition code is set equal to bits 34 and 35 of the supervisor call new PSW. It remains unchanged in the old PSW.

SW\*

PAGE

Floating Point



#### Function:

Causes the contents of a double word in main storage specified by operand 2 to be algebraically subtracted from the contents of the double word in the register specified by operand 1  $(r_1)$ . The difference is placed in the double word operand 1  $(r_1)$  register.

#### **Explicit Format:**

| LABEL    | $\Delta$ OPERATION $\Delta$ | OPERAND                                                          |
|----------|-----------------------------|------------------------------------------------------------------|
| [symbol] | sw                          | r <sub>1</sub> ,d <sub>2</sub> (x <sub>2</sub> ,b <sub>2</sub> ) |

#### Implicit Format:

| LABEL    | $\Delta$ OPERATION $\Delta$ | OPERAND                                          |
|----------|-----------------------------|--------------------------------------------------|
| [symbol] | sw                          | r <sub>1</sub> ,s <sub>2</sub> (x <sub>2</sub> ) |

#### Operational Consideration:

■ The execution of the SW instruction is identical to that of the AW instruction, except that the sign is reversed before addition.

<sup>\*</sup> SW is a featured instruction. If you attempt to issue this instruction to a processor which does not have the control feature installed, you cause an operation program exception.

## SWR\*

### Floating Point

| General |              |                                                               |                          | Possible Program Exceptions                                             |                                                                                                      |  |
|---------|--------------|---------------------------------------------------------------|--------------------------|-------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------|--|
| OPCODE  |              | FORMAT<br>TYPE                                                | OBJECT<br>INST.<br>LGTH. | ☐ ADDRESSING ☐ DATA (INVALID SIGN/DIGIT)                                | PROTECTION SIGNIFICANCE                                                                              |  |
| MNEM.   | HEX.         |                                                               | (BYTES)                  | DECIMAL DIVIDE                                                          | SPECIFICATION:                                                                                       |  |
| SWR     | 2F           | RR                                                            | 2                        | DECIMAL OVERFLOW  EXECUTE                                               | NOT A FLOATING-POINT REGISTER  OP 1 NOT ON HALF-WORD BOUNDARY                                        |  |
|         | Conc         | lition Code                                                   | s                        | EXPONENT OVERFLOW  EXPONENT UNDERFLOW                                   | OP 2 NOT ON HALF-WORD BOUNDARY  OP 2 NOT ON FULL-WORD BOUNDARY  OP 2 NOT ON DOUBLE-WORD              |  |
| IF RE   | SULT<br>SULT | = 0, SET TO<br>< 0, SET TO<br>> 0, SET TO<br>OW, SET TO<br>ED | ) 1<br>) 2               | FIXED-POINT DIVIDE FIXED-POINT OVERFLOW FLOATING-POINT DIVIDE OPERATION | OP 2 NOT ON DOUBLE-WORD BOUNDARY OP 1 NOT EVEN NUMBERED REGISTER OP 1 NOT ODD NUMBERED REGISTER NONE |  |

#### Function:

Causes the contents of the double word in the operand 2 (r<sub>2</sub>) register to be algebraically subtracted from the double word contents of the operand 1 (r<sub>1</sub>) register. The difference is placed in the double operand 1 (r<sub>1</sub>) register.

## **Explicit and Implicit Format:**

| LABEL    | $\Delta$ OPERATION $\Delta$ | OPERAND                        |
|----------|-----------------------------|--------------------------------|
| [symbol] | SWR                         | r <sub>1</sub> ,r <sub>2</sub> |

## **Operational Consideration:**

The execution of the SWR instruction is identical to that of the AWR instruction, except that the sign is reversed before addition.

SWR is a featured instruction. If you attempt to issue this instruction to a processor which does not have the control feature installed, you cause an operation program exception.

TM

| General               |                      |                |                          | Possible Program Exceptions                                             |                                                                                                      |  |
|-----------------------|----------------------|----------------|--------------------------|-------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------|--|
| OPCODE                |                      | FORMAT<br>TYPE | OBJECT<br>INST.<br>LGTH. | ADDRESSING DATA (INVALID SIGN/DIGIT)                                    | PROTECTION SIGNIFICANCE                                                                              |  |
| MNEM.                 | HEX.                 | 1,             | (BYTES)                  | DECIMAL DIVIDE                                                          | SPECIFICATION:                                                                                       |  |
| TM                    | 91                   | SI             | 4                        | DECIMAL OVERFLOW EXECUTE                                                | OP 1 NOT ON HALF-WORD BOUNDARY                                                                       |  |
| Condition Codes       |                      |                |                          | EXPONENT OVERFLOW  EXPONENT UNDERFLOW                                   | OP 2 NOT ON HALF-WORD BOUNDARY OP 2 NOT ON FULL-WORD BOUNDARY OP 2 NOT ON DOUBLE-WORD                |  |
| SET TO SET TO SEE OPE | ro 1<br>ro 2<br>ro 3 | INSIDERATI     | IONS                     | FIXED-POINT DIVIDE FIXED-POINT OVERFLOW FLOATING-POINT DIVIDE OPERATION | OP 2 NOT ON DOUBLE-WORD BOUNDARY OP 1 NOT EVEN NUMBERED REGISTER OP 1 NOT ODD NUMBERED REGISTER NONE |  |

#### Function:

Causes one byte in main storage specified by operand 1 to be tested for 1 bits according to the 8-bit mask specified in operand 2. The condition code is set to reflect the results of the test.

### **Explicit Format:**

| LABEL    | $\Delta$ OPERATION $\Delta$ | OPERAND                                         |
|----------|-----------------------------|-------------------------------------------------|
| [symbol] | TM                          | d <sub>1</sub> (b <sub>1</sub> ),i <sub>2</sub> |

## Implicit Format:

| LABEL    | △ OPERATION △ | OPERAND                        |  |  |
|----------|---------------|--------------------------------|--|--|
| [symbol] | ТМ            | s <sub>1</sub> ,i <sub>2</sub> |  |  |

#### **Operational Considerations:**

- The 1 bits of the immediate operand 2 are used to test the bits of operand 1.
- The contents of operand 1 remain unchanged.
- The condition code is set:
  - to zero if all the 1 bits in the mask match zero bits in the byte tested or if all the bits in the mask are zero;
  - to 1 if some of the 1 bits in the mask match zero bits in the byte tested; or
  - to 3 if all the 1 bits in the mask correspond with 1 bits in the byte tested.

Code 2 is not used.

## TR

|                                                                                                                   |                 | General        |                          | Possible Program Exceptions                                                   |                                                                                                      |  |
|-------------------------------------------------------------------------------------------------------------------|-----------------|----------------|--------------------------|-------------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------|--|
| OPCODE                                                                                                            |                 | FORMAT<br>TYPE | OBJECT<br>INST.<br>LGTH. |                                                                               | l <del>_</del>                                                                                       |  |
| MNEM.                                                                                                             | HEX.            |                | (BYTES)                  | DECIMAL DIVIDE                                                                | SPECIFICATION:                                                                                       |  |
| TR                                                                                                                | DC              | SS             | 6                        | DECIMAL OVERFLOW  EXECUTE                                                     | OP 1 NOT ON HALF-WORD BOUNDARY                                                                       |  |
|                                                                                                                   | Condition Codes |                |                          | EXPONENT OVERFLOW  EXPONENT UNDERFLOW                                         | OP 2 NOT ON HALF-WORD BOUNDARY OP 2 NOT ON FULL-WORD BOUNDARY OP 2 NOT ON DOUBLE-WORD                |  |
| ☐ IF RESULT = 0, SET TO 0 ☐ IF RESULT < 0, SET TO 1 ☐ IF RESULT > 0, SET TO 2 ☐ IF OVERFLOW, SET TO 3 ☐ UNCHANGED |                 |                |                          | FIXED-POINT DIVIDE FIXED-POINT OVERFLOW STORM FLOATING-POINT DIVIDE OPERATION | OP 2 NOT ON DOUBLE-WORD BOUNDARY OP 1 NOT EVEN NUMBERED REGISTER OP 1 NOT ODD NUMBERED REGISTER NONE |  |

### Function:

Causes the contents of operand 1 to be translated according to a table in main storage specified by operand 2. As a result, operand 1 will contain data copied from the operand 2 table.

## **Explicit Format:**

| LABEL    | $\Delta$ OPERATION $\Delta$ | OPERAND                                                             |  |  |  |
|----------|-----------------------------|---------------------------------------------------------------------|--|--|--|
| [symbol] | TR                          | d <sub>1</sub> (I,b <sub>1</sub> ),d <sub>2</sub> (b <sub>2</sub> ) |  |  |  |

## Implicit Format:

| LABEL    | △ OPERATION △ | OPERAND                           |  |  |  |
|----------|---------------|-----------------------------------|--|--|--|
| [symbol] | TR            | s <sub>1</sub> (I),s <sub>2</sub> |  |  |  |

- The 8-bit code of each character of operand 1 is used as an index to the base table address specified by operand 2. The character code located at this address 8-bit code value of operand 1 plus d2(b2) is transferred from the table to the character position of operand 1. Thus, the original 8-bit code of operand 1 is replaced.
- Translation continues until all characters specified by the length (I) have been translated.
- The contents of the table are not changed unless overlap occurs.

TR

- If the number of bytes to be translated is not explicitly shown in operand 1, then the number will be equal to the length attribute of operand 1.
- The programmer may place whatever values are required into the 256-byte translate table. When it is known what kind of bit configurations are expected as input (each unique configuration produces an address pointing to a unique table address), the desired value may be placed in the table to produce a translation.

|         |                                                              | General        |                          | Possible Program Exceptions                                             |                                                                                                      |  |
|---------|--------------------------------------------------------------|----------------|--------------------------|-------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------|--|
| OPCODE  |                                                              | FORMAT<br>TYPE | OBJECT<br>INST.<br>LGTH. | ADDRESSING DATA (INVALID SIGN/DIGIT)                                    | PROTECTION SIGNIFICANCE                                                                              |  |
| MNEM.   | HEX.                                                         | , , , ,        | (BYTES)                  | DECIMAL DIVIDE                                                          | SPECIFICATION:                                                                                       |  |
| TRT     | DD                                                           | SS             | 6                        | DECIMAL OVERFLOW SEXECUTE                                               | OP 1 NOT ON HALF-WORD BOUNDARY                                                                       |  |
|         | Condition Codes                                              |                |                          | EXPONENT OVERFLOW  EXPONENT UNDERFLOW                                   | OP 2 NOT ON HALF-WORD BOUNDARY OP 2 NOT ON FULL-WORD BOUNDARY OP 2 NOT ON DOUBLE-WORD                |  |
| SET SET | SET TO 0 SET TO 1 SET TO 2 SET TO 3 SEE OPER. CONSIDERATIONS |                |                          | FIXED-POINT DIVIDE FIXED-POINT OVERFLOW FLOATING-POINT DIVIDE OPERATION | OP 2 NOT ON DOUBLE-WORD BOUNDARY OP 1 NOT EVEN NUMBERED REGISTER OP 1 NOT ODD NUMBERED REGISTER NONE |  |

#### Function:

Causes the contents of operand 1 to be translated according to a table in main storage specified by operand 2. The resultant data in the table will be tested and condition code set.

### **Explicit Format:**

| LABEL    | $\Delta$ OPERATION $\Delta$ | OPERAND                                                             |  |  |  |
|----------|-----------------------------|---------------------------------------------------------------------|--|--|--|
| [symbol] | TRT                         | d <sub>1</sub> (I,b <sub>1</sub> ),d <sub>2</sub> (b <sub>2</sub> ) |  |  |  |

#### Implicit Format:

| LABEL    | $\Delta$ OPERATION $\Delta$ | OPERAND                           |  |  |  |
|----------|-----------------------------|-----------------------------------|--|--|--|
| [symbol] | TRT                         | s <sub>1</sub> (I),s <sub>2</sub> |  |  |  |

- The *translate and test* (TRT) instruction searches the table in the same manner as the *translate* (TR) instruction.
- The selected byte (result byte) in the translate table is examined and tested for an all zero pattern. If the result byte is all zeros, it is ignored and the translate operation is continued. If the result byte is nonzero, the address of the corresponding operand 1 byte is stored in the least significant 24 bit positions of general register 1, the result byte is stored in the least significant 8-bit positions of general register 2, and the operation is terminated.

**TRT** 

- The contents of both operands remain unchanged.
- If the maximum number of bytes to be translated is not explicitly shown in operand 1, then the number will be equal to the length attribute of operand 1.
- The condition code is set:
  - to zero if all result bytes are zero;
  - to 1 if the result byte corresponding to any except the last operand 1 byte is nonzero; or
  - to 2 if the result byte corresponding to the last operand 1 byte is nonzero.

Code 3 is not used.

| General         |              |           |                          | Possible Program Exceptions                                                |                                                                                                 |  |
|-----------------|--------------|-----------|--------------------------|----------------------------------------------------------------------------|-------------------------------------------------------------------------------------------------|--|
| OPCODE          |              | FORMAT    | OBJECT<br>INST.<br>LGTH. | ■ ADDRESSING □ DATA (INVALID SIGN/DIGIT)                                   | PROTECTION SIGNIFICANCE                                                                         |  |
| MNEM.           | HEX.         | (BYTES)   |                          | DECIMAL DIVIDE                                                             | SPECIFICATION:                                                                                  |  |
| TS              | 93           | SI        | 4                        | DECIMAL OVERFLOW  EXECUTE                                                  | OP 1 NOT ON HALF-WORD BOUNDARY                                                                  |  |
| Condition Codes |              |           | !S                       | EXPONENT OVERFLOW  EXPONENT UNDERFLOW                                      | OP 2 NOT ON HALF-WORD BOUNDARY OP 2 NOT ON FULL-WORD BOUNDARY                                   |  |
| SET 1           | TO 1<br>TO 2 |           |                          | FIXED-POINT DIVIDE  FIXED-POINT OVERFLOW  FLOATING-POINT DIVIDE  OPERATION | OP 2 NOT ON DOUBLE-WORD BOUNDARY OP 1 NOT EVEN NUMBERED REGISTER OP 1 NOT ODD NUMBERED REGISTER |  |
| SEE OPE         | ER, CO       | NSIDERATI | ONS                      |                                                                            | ☐ NONE                                                                                          |  |

#### Function:

Causes the operand, a byte in main storage, to be read and bit position 0 to be tested. After the byte is tested and the condition code is set, all the bits in this indicator byte are set to 1. The byte indicated by the operand can be used as an indicator switch which is tested and set to all binary 1's by this instruction and then reset to binary 0's by some other instruction.

#### **Explicit Format:**

| LABEL    | $\Delta$ OPERATION $\Delta$ | OPERAND                          |
|----------|-----------------------------|----------------------------------|
| [symbol] | TS                          | d <sub>1</sub> (b <sub>1</sub> ) |

## Implicit Format:

| LABEL    | $\Delta$ OPERATION $\Delta$ |                | OPERAND |
|----------|-----------------------------|----------------|---------|
| [symbol] | TS                          | s <sub>1</sub> |         |

- Only the first bit of the operand is tested to determine the condition code.
- All eight bits of the operand are set to binary 1's after the condition code is set.
- The condition code is set as follows:
  - O if bit position 0 is zero; or
  - 1 if bit position 0 is one.

<sup>\*</sup> TS is a featured instruction. If you attempt to issue this instruction to a processor which does not have the control feature installed, you cause an operation program exception.

| General                                                                                                           |      |                |                                               | Possible Program Exceptions                                             |                                                                                                      |
|-------------------------------------------------------------------------------------------------------------------|------|----------------|-----------------------------------------------|-------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------|
| OPCODE                                                                                                            |      | FORMAT<br>TYPE | OBJECT INST. LGTH.  DATA (INVALID SIGN/DIGIT) | PROTECTION SIGNIFICANCE                                                 |                                                                                                      |
| MNEM.                                                                                                             | HEX. | ,              | (BYTES)                                       | DECIMAL DIVIDE                                                          | SPECIFICATION:                                                                                       |
| UNPK                                                                                                              | F3   | SS             | 6                                             | DECIMAL OVERFLOW  EXECUTE                                               | OP 1 NOT ON HALF-WORD BOUNDARY                                                                       |
| Condition Codes                                                                                                   |      |                | s                                             | EXPONENT OVERFLOW  EXPONENT UNDERFLOW                                   | OP 2 NOT ON HALF-WORD BOUNDARY OP 2 NOT ON FULL-WORD BOUNDARY                                        |
| ☐ IF RESULT = 0, SET TO 0 ☐ IF RESULT < 0, SET TO 1 ☐ IF RESULT > 0, SET TO 2 ☐ IF OVERFLOW, SET TO 3 ☐ UNCHANGED |      |                | ) 1<br>) 2                                    | FIXED-POINT DIVIDE FIXED-POINT OVERFLOW FLOATING-POINT DIVIDE OPERATION | OP 2 NOT ON DOUBLE WORD BOUNDARY OP 1 NOT EVEN NUMBERED REGISTER OP 1 NOT ODD NUMBERED REGISTER NONE |

#### Function:

Converts the contents of operand 2 from a packed format to an unpacked format, which is placed in operand 1.

#### **Explicit Format:**

| LABEL    | $\Delta$ OPERATION $\Delta$ | OPERAND                                                                                           |  |
|----------|-----------------------------|---------------------------------------------------------------------------------------------------|--|
| [symbol] | UNPK                        | d <sub>1</sub> (l <sub>1</sub> ,b <sub>1</sub> ),d <sub>2</sub> (l <sub>2</sub> ,b <sub>2</sub> ) |  |

#### Implicit Format:

| LABEL    | $\Delta$ OPERATION $\Delta$ | OPERAND                                                           |
|----------|-----------------------------|-------------------------------------------------------------------|
| [symbol] | UNPK -                      | s <sub>1</sub> (I <sub>1</sub> ),s <sub>2</sub> (I <sub>2</sub> ) |

- This instruction proceeds one byte at a time from right to left. The first byte operated on has its sign and digit reversed (a 4C would become C4). Each half byte from then on is moved to the next left digit field, and an F is placed in the zone field of the receiving byte (EBCDIC notation).
- Any unfilled bytes that are part of the specified length for operand 1 are zero-filled.
- Operand 2 data should be in packed decimal format.
- Operand 1 should contain enough bytes to receive all digits, a zone for each digit, and a sign from operand 2.
- Specification of a length attribute for operands 1 and 2 is optional.



#### Function:

Causes a logical exclusive OR operation to be performed on the contents of the operand 1 (r<sub>1</sub>) register and the full word in main storage specified by operand 2. The result is placed in operand 1 (r<sub>1</sub>).

## **Explicit Format:**

| LABEL    | $\Delta$ OPERATION $\Delta$ | OPERAND                                                          |
|----------|-----------------------------|------------------------------------------------------------------|
| [symbol] | ×                           | r <sub>1</sub> ,d <sub>2</sub> (x <sub>2</sub> ,b <sub>2</sub> ) |

#### Implicit Format:

| LABEL    | $\Delta$ OPERATION $\Delta$ | OPERAND                                          |
|----------|-----------------------------|--------------------------------------------------|
| [symbol] | ×                           | r <sub>1</sub> ,s <sub>2</sub> (x <sub>2</sub> ) |

- A bit position in the result is set to 1 if the corresponding bit positions in the operands are unlike; otherwise, the bit position in the result is set to zero.
- The rules of operation for the exclusive OR (X) operation are illustrated by the following truth table:

| Operand 1 | Operand 2 | Result<br>(Operand 1) |
|-----------|-----------|-----------------------|
| 0         | 0         | 0                     |
| 1         | 0         | 1                     |
| 0         | 1         | 1                     |
| 1         | 1         | 0                     |

| General                                                                                                           |                 |                |                                                                         | Possible Program Exceptions                                                                          |                                                               |
|-------------------------------------------------------------------------------------------------------------------|-----------------|----------------|-------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------|---------------------------------------------------------------|
| орсо                                                                                                              | DE              | FORMAT<br>TYPE | OBJECT<br>INST.<br>LGTH.                                                | ■ ADDRESSING ■ PROTECTION  □ DATA (INVALID SIGN/DIGIT) □ SIGNIFICANCE                                |                                                               |
| MNEM.                                                                                                             | HEX.            |                | (BYTES)                                                                 | DECIMAL DIVIDE SPECIFICATION:                                                                        |                                                               |
| ХC                                                                                                                | D7              | SS             | 6                                                                       | DECIMAL OVERFLOW  EXECUTE                                                                            | OP 1 NOT ON HALF WORD BOUNDARY                                |
|                                                                                                                   | Condition Codes |                | s                                                                       | EXPONENT OVERFLOW  EXPONENT UNDERFLOW                                                                | OP 2 NOT ON HALF WORD BOUNDARY OP 2 NOT ON FULL WORD BOUNDARY |
| ■ IF RESULT = 0, SET TO 0 ■ IF RESULT ≠ 0, SET TO 1 □ IF RESULT > 0, SET TO 2 □ IF OVERFLOW, SET TO 3 □ UNCHANGED |                 | ) 1            | FIXED POINT DIVIDE FIXED POINT OVERFLOW FLOATING POINT DIVIDE OPERATION | OP 2 NOT ON DOUBLE WORD BOUNDARY OP 1 NOT EVEN NUMBERED REGISTER OP 1 NOT ODD NUMBERED REGISTER NONE |                                                               |

#### Function:

Causes a logical exclusive OR operation to be performed on the contents of the areas in main storage specified by operand 1 and operand 2. The result is placed in operand 1.

## **Explicit Format:**

| LABEL    | $\Delta$ operation $\Delta$ | OPERAND                                                             |
|----------|-----------------------------|---------------------------------------------------------------------|
| [symbol] | хс                          | d <sub>1</sub> (I,b <sub>1</sub> ),d <sub>2</sub> (b <sub>2</sub> ) |

## Implicit Format:

| LABEL    | $\Delta$ OPERATION $\Delta$ | OPERAND                           |
|----------|-----------------------------|-----------------------------------|
| [symbol] | хс                          | s <sub>1</sub> (I),s <sub>2</sub> |

- A bit position in the result is set to 1 if the corresponding bit positions in the operands are unlike; otherwise, the bit position in the result is set to zero.
- The rules of operation for the exclusive OR operation are illustrated by the following truth table:

| Operand 1 | Operand 2 | Result<br>(Operand 1) |
|-----------|-----------|-----------------------|
| 0         | 0         | 0                     |
| 1         | 0         | 1                     |
| 0         | 1         | 1                     |
| 1         | 1         | 0                     |

XC

- The number of bytes used in each operand is specified by I in operand 1.
- If the number of bytes to be used in each operand is not explicitly shown in operand 1, then the number will be equal to the length attribute of operand 1.

#### Function:

Causes a logical exclusive OR operation to be performed on the contents of operand 1 (a byte in main storage) and operand 2 (a byte of immediate data in the instruction). The result is placed in operand 1.

#### **Explicit Format:**

| LABEL    | $\Delta$ operation $\Delta$ | OPERAND                                         |
|----------|-----------------------------|-------------------------------------------------|
| [symbol] | ΧI                          | d <sub>1</sub> (b <sub>1</sub> ),i <sub>2</sub> |

### Implicit Format:

| LABEL    | $\Delta$ OPERATION $\Delta$ | OPERAND                        |
|----------|-----------------------------|--------------------------------|
| [symbol] | XI                          | s <sub>1</sub> ,i <sub>2</sub> |

- A bit position in the result is set to 1 if the corresponding bit positions in the operands are unlike; otherwise, the bit position in the result is set to zero.
- The rules of operation for the exclusive OR (XI) operation are illustrated by the following truth table:

| Operand 1 | Operand 2 | Result<br>(Operand 1) |
|-----------|-----------|-----------------------|
| 0         | 0         | 0                     |
| 1         | 0         | 1                     |
| 0         | 1         | 1                     |
| 1         | 1         | 0                     |

|                                                                                                         | General         |                |                          | Possible Program Exceptions                                             |                                                                                                      |  |
|---------------------------------------------------------------------------------------------------------|-----------------|----------------|--------------------------|-------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------|--|
| орсо                                                                                                    | DE              | FORMAT<br>TYPE | OBJECT<br>INST.<br>LGTH. | ☐ ADDRESSING ☐ DATA (INVALID SIGN/DIGIT)                                | PROTECTION SIGNIFICANCE                                                                              |  |
| MNEM.                                                                                                   | HEX.            | 1,1,2          | (BYTES)                  | DECIMAL DIVIDE                                                          | SPECIFICATION:                                                                                       |  |
| XR                                                                                                      | 17              | RR             | 2                        | ☐ EXECUTE                                                               | OP 1 NOT ON HALF-WORD BOUNDARY                                                                       |  |
|                                                                                                         | Condition Codes |                |                          | EXPONENT OVERFLOW  EXPONENT UNDERFLOW                                   | OP 2 NOT ON HALF-WORD BOUNDARY OP 2 NOT ON FULL-WORD BOUNDARY OP 2 NOT ON DOUBLE-WORD                |  |
| IF RESULT = 0, SET TO 0 IF RESULT ≠ 0, SET TO 1 IF RESULT > 0, SET TO 2 IF OVERFLOW, SET TO 3 UNCHANGED |                 |                | ) 1<br>) 2               | FIXED-POINT DIVIDE FIXED-POINT OVERFLOW FLOATING-POINT DIVIDE OPERATION | OP 2 NOT ON DOUBLE-WORD BOUNDARY OP 1 NOT EVEN NUMBERED REGISTER OP 1 NOT ODD NUMBERED REGISTER NONE |  |

#### Function:

Causes a logical exclusive OR operation to be performed on the contents of the registers specified by operand 1 ( $r_1$ ) and operand 2 ( $r_2$ ). The result is placed in operand 1 ( $r_1$ ).

## Explicit and Implicit Format:

| LABEL    | $\Delta$ OPERATION $\Delta$ | OPERAND                        |
|----------|-----------------------------|--------------------------------|
| [symbol] | XR                          | r <sub>1</sub> ,r <sub>2</sub> |

- A bit position in the result is set to 1 if the corresponding bit positions in the operands are unlike; otherwise, the bit position in the result is set to zero.
- The rules of operation for the exclusive OR (XR) operation are illustrated by the following truth table:

| Operand 1 | Operand 2 | Result<br>(Operand 1) |
|-----------|-----------|-----------------------|
| 0         | 0         | 0                     |
| 1         | 0         | 1                     |
| 0         | 1         | 1                     |
| 1         | 1         | 0 .                   |



#### Function:

Clears operand 1 to zeros and adds the value of operand 2. Replaces operand 1 with the value of operand 2.

#### **Explicit Format:**

| LABEL    | $\Delta$ OPERATION $\Delta$ | OPERAND                                                                                           |
|----------|-----------------------------|---------------------------------------------------------------------------------------------------|
| [symbol] | ZAP                         | d <sub>1</sub> (l <sub>1</sub> ,b <sub>1</sub> ),d <sub>2</sub> (l <sub>2</sub> ,b <sub>2</sub> ) |

#### Implicit Format:

| LABEL    | $\Delta$ operation $\Delta$ | OPERAND                                                           |
|----------|-----------------------------|-------------------------------------------------------------------|
| [symbol] | ZAP                         | s <sub>1</sub> (I <sub>1</sub> ),s <sub>2</sub> (I <sub>2</sub> ) |

- Equivalent to AP with zero in operand 1. Sign digit is generated.
- Checks operand 2 sign and digits for validity.
- Decimal overflow condition exists when operand 2 value will not fit in operand 1. Most significant digits are truncated.
- Zero result has positive sign. When overflow occurs, zero result has sign of operand 2.
- Operand 2 is zero extended when it does not fill operand 1.
- Operands 1 and 2 may overlap if least significant bytes coincide, or if least significant byte of operand
   1 is to the right of the least significant byte of operand

|   |  | 4         |
|---|--|-----------|
|   |  |           |
|   |  |           |
|   |  |           |
|   |  |           |
|   |  |           |
|   |  |           |
|   |  |           |
|   |  |           |
|   |  |           |
|   |  | <b>3.</b> |
|   |  |           |
|   |  |           |
| · |  |           |
|   |  |           |
|   |  |           |
|   |  |           |
|   |  |           |
|   |  |           |
| • |  |           |
|   |  |           |
|   |  |           |
|   |  |           |
|   |  |           |
|   |  |           |
|   |  |           |
|   |  |           |
|   |  |           |
|   |  |           |
|   |  |           |
|   |  |           |
|   |  |           |
|   |  |           |
|   |  |           |
|   |  |           |
|   |  |           |
|   |  |           |
|   |  |           |
|   |  |           |
|   |  |           |
|   |  |           |
|   |  |           |
|   |  |           |
|   |  |           |
|   |  |           |
|   |  |           |
|   |  |           |
|   |  |           |
|   |  |           |
|   |  |           |
|   |  |           |
|   |  |           |
|   |  |           |
|   |  |           |
|   |  |           |
|   |  |           |

3. BAL Directives

• • •

**CCW** 

### **Function:**

Defines and generates an 8-byte channel command word aligned on a double-word boundary.

For full information on the use of the CCW, refer to the processor programmer reference, UP-8052 (current version).

#### Format:

| LABEL    | $\Delta$ operation $\Delta$ | OPERAND                                                            |
|----------|-----------------------------|--------------------------------------------------------------------|
| [symbol] | CCW                         | op <sub>1</sub> ,op <sub>2</sub> ,op <sub>3</sub> ,op <sub>4</sub> |

#### where:

op<sub>1</sub>
Is the command code specifying the operation to be performed.

op<sub>2</sub>
Is the address of the first byte in main storage of the data being controlled.

 $\ensuremath{\text{op}_3}$  is the flag control indicating the options desired.

op<sub>4</sub>
Is the byte count indicating the number of bytes of data to be controlled.

## CNOP

#### Function:

Adjusts the location counter to a half-word, full-word, or double-word storage boundary without initiating any other operation.

#### Format:

| LABEL  | $\Delta$ OPERATION $\Delta$ | OPERAND                        |
|--------|-----------------------------|--------------------------------|
| unused | CNOP                        | a <sub>1</sub> ,a <sub>2</sub> |

#### where:

 $\mathbf{a}_1$  and  $\mathbf{a}_2$ 

Are absolute expressions consisting of predefined terms.

## **Operational Considerations:**

The first expression in the operand field indicates a byte to which the location counter must be set. Legal values for the first expression are zero and 2 for full-word boundary alignment, and zero, 2, 4, and 6 for double-word boundary alignment, as follows:

- Zero indicates a full-word or double-word boundary.
- A 2 indicates the second byte (first half word) past the boundary.
- A 4 indicates the fourth byte (second half word) past a double-word boundary.
- A 6 indicates the sixth byte (third half word) past a double-word boundary.

Permissible values for the second expression are 4 and 8, indicating that the adjustment is relative to a full-word or double-word boundary, respectively.

If the location counter is already set to the indicated byte, the CNOP has no effect. When alignment is needed, one, two, or three no-operation instructions are generated to increment the location counter to the proper half-word boundary and to ensure correct instruction processing. All terms must be predefined.

COM

#### Function:

Enables the programmer to define a control section to be used as a common storage area for two or more separately assembled routines. The format of the common section may be described by DS and DC directives. Labels appearing within the sections are defined. Like a dummy control section, no data or instructions are assembled in a common section. It has a separate location counter with an initial value of zero. Data may be entered into a common section only by execution of a program which refers to it. DC instructions act as DS instructions in the COM area because neither instructions nor constants in a common storage area are assembled. Labels defined in a common section are not subject to the restrictions imposed on dummy section labels.

One assembly can define only one common section. However, several COM directives may appear among the source statements. Each COM directive after the first defines a continuation of the common section previously described. When several routines defining common storage are linked, the resulting module contains only one section corresponding to the common sections in the input modules. The length of this section is the length of the largest like common section in the input modules.

#### Format:

| LABEL    | △ OPERATION △ | OPERAND |
|----------|---------------|---------|
| [symbol] | СОМ           | unused  |

#### **Operational Considerations:**

If the common section is unlabeled, the area is addressed by referencing the label of a statement within the common section with a USING directive.

If more than one object module element refers to a common storage area with the same name, the references are to the same storage area. Only one common storage area is allocated within a load module to satisfy all object module requests for common storage areas with the same name. The size of a common storage area in a load module is determined by the maximum size requested by any object module for common storage with that name. Blank common storage areas are allocated in the same way.

In a multiphase load module, common storage areas are not normally overlaid.

The following rules apply to the use of common storage:

- An entry point cannot have the same name as a labeled common storage area included in the load module.
- When the linkage editor includes module elements (CSECT or COM) with the same name as a labeled common storage area, that section is treated as a block data subprogram (i.e., to initialize values of labeled common blocks) and is loaded into all or a portion of the common storage area. A block data subprogram is loaded when the phase in which it was included is loaded. Blank common cannot be initialized during loading unless the text encountered is for that COM ESD.

# COM

— If an object module has requested common storage, the partial inclusion of a single control section from that object module will cause the common storage area defined to be included also, regardless of whether or not the included control section refers to that common storage name. For further information, see the linkage editor portion in system service programs (SSP) user guide, UP-8062 (current version).

COPY

# Function:

Causes the source module identified in the operand field of the COPY directive to be included directly into the source program being assembled.

# Format:

| LABEL  | $\Delta$ OPERATION $\Delta$ | OPERAND |
|--------|-----------------------------|---------|
| unused | COPY                        | symbol  |

where:

#### symbol

Identifies the code to be copied by the assembler. Only one symbol may be used.

# Operational Considerations:

The assembler places the source code, identified by the operand, immediately after the COPY directive. This source module may not include any COPY, END, ICTL, MACRO, or MEND directives. Statements included in the program by a COPY directive are assumed to be in standard format regardless of any ICTL directives in the program.

# **CSECT**

Function:

Indicates the initiation or continuation of a control section.

Format:

| LABEL    | $\Delta$ OPERATION $\Delta$ | OPERAND |
|----------|-----------------------------|---------|
| [symbol] | CSECT                       | unused  |

#### **Operational Considerations:**

The symbolic name of the control section defines an entry point of the program being assembled. This symbol must not appear as a symbol for any other source statement except the START directive of its control section or another CSECT directive to indicate continuation of the coding in the same control section.

Each control section is adjusted to begin on a double-word boundary. The value of the symbol is the address of the first byte of the control section and has a length attribute of 1.

If the symbol is blank, the CSECT directive is a continuation of coding for an unnamed control section. If the symbol is blank and is not preceded by an unnamed control section, the CSECT initiates an unnamed control section. Only one unnamed control section is permitted in a module.

PAGE

Floating Point

#### Function:

Defines the value of a floating-point number and has a program storage location assigned to it. The format of floating-point constants differs from the standard format of the DC statement in that an additional subfield may appear — the scale modifier.

#### Format:

| LABEL    | $\Delta$ OPERATION $\Delta$ | OPERAND                               |
|----------|-----------------------------|---------------------------------------|
| [symbol] | DC                          | [d] t[L <sub>n</sub> ][S+n] 'c[E±n] ' |

#### where:

#### [symbol]

Is up to eight characters.

d

The duplication factor designates the number of identical constants or areas to be generated. An unsigned decimal value is used to specify the duplication factor. If no duplication subfield is used, the assembler assumes a factor of 1. A duplication factor of zero generates neither a constant nor a storage area and, if no length factor is specified, the location counter will provide the proper boundary alignment and assign the location counter value to the symbol used. A duplication factor of zero is not permitted with literals. Even though the duplication factor can change the size of the storage area used, the use of the duplication factor does not change the length attribute of the field. The maximum value of the duplication factor is 256.

t The definition-type symbol is required to determine the alignment, padding, truncation, storage form, and implied length. (See Table A-6 for the characteristics of the E and D types.)

Ln

Is the explicit length factor in decimal. Two types of floating-point constants are available: full word (E) and double word (D). The implied length of an E type constant is four bytes; if the length modifier is omitted, full-word boundary alignment is assigned. The implied length of a D type constant is eight bytes; if the length modifier is omitted, double-word boundary alignment is assigned. In either case, an explicit length modifier of from one to eight bytes may be specified.

#### S+n

Is the scale modifier and must be a positive signed or unsigned decimal number. If the sign is omitted, a positive value is assumed. The scale modifier is applied to a number after it has been converted to internal format.

# DC

#### Floating Point

#### 'c[E±n]'

Is the constant specification with optional exponent. A floating-point number is written as a decimal number which may be an integer (110), a fraction (75), or a mixed number (110.75). The floating-point number may be followed by an optional exponent represented by an E, a sign, and a decimal number, respectively. In the absence of a sign, a plus sign is assumed. The exponent for a constant is that power of 10 by which that constant will be multiplied before its conversion to internal format. This exponent value may range from -85 to +75.

# **Operational Considerations:**

The machine representation of the constant consists of a hexadecimal fraction (mantissa) and a hexadecimal exponent (characteristic). The arithmetic point is assumed to be at the left of the leftmost digit of the fraction. The characteristic represents the power of 16 by which the fraction must be multiplied to obtain the value of the constant. The machine format is as follows:

#### (SHORT FORMAT) **FULL** mantissa characteristic (fraction) WORD (exponent) 0 7 8 6 hexadecimal digits 31 (LONG FORMAT) mantissa **DOUBLE** characteristic (fraction) WORD (exponent) 14 hexadecimal digits 7 8 63

# where:

#### sign

Is the zero bit, the sign of the mantissa.

#### characteristic

Is a 7-bit binary number (signed and biased by the hexadecimal value 40<sub>16</sub>, decimal value 64) reflecting the scaling of the floating-point number.

# mantissa

Is the fraction after the constant has been converted to its machine representation; scaling is performed if specified.

# NOTE:

The floating-point value is the product of the mantissa (fraction) and the base 16 raised to the power of the biased characteristic (exponent) after the exponent has been reduced by 64.

DC

Standard Format

#### Function:

Defines the value of a decimal number, an alphanumeric expression, or address constant and has a program storage location assigned to it.

#### Format:

| LABEL    | $\Delta$ operation $\Delta$ | OPERAND                    |
|----------|-----------------------------|----------------------------|
| [symbol] | DC                          | $[d]t[L_n]{\binom{c'}{c}}$ |

where:

#### [symbol]

Is up to eight characters long.

d

The duplication factor designates the number of identical constants or areas to be generated. An unsigned decimal value is used to specify the duplication factor. If no duplication subfield is used, the assembler assumes a factor of 1. A duplication factor of zero generates neither a constant nor a storage area and, if no length factor is specified, the location counter will provide the proper boundary alignment and assigns the location counter value to the symbol used. A duplication factor of zero is not permitted with literals. Even though the duplication factor can change the size of the storage area used, the use of the duplication factor does not change the length attribute of the field. The maximum value of the duplication factor is 256.

t

The definition-type symbol is required for both DC and DS statement to determine the alignment, padding, truncation, storage form, and implied length. (See Table A—6 for the characteristics of the 13 types used.)

Ln

The length factor designates the explicit value of the length attribute of a field generated by a DS or DC statement. The length attribute of a field used in an assembler application instruction determines the number of bytes involved in that instruction. The maximum value of the length factor is 256. Boundary alignment is not provided when a length factor is specified.

#### 'c' or (c)

The constant specification determines the constant, or storage, to be generated. When an apostrophe or ampersand is included in the constant specification, double apostrophes or ampersands are used to indicate the inclusion of these characters in the constant. The constant may take the form of data or an address, as shown in Table A—6.

# Function:

Informs the assembler that the registers specified are no longer available for base register assignment.

#### Format:

| LABEL  | $\Delta$ operation $\Delta$ | OPERAND                            |
|--------|-----------------------------|------------------------------------|
| unused | DROP                        | r <sub>1</sub> [,,r <sub>n</sub> ] |

# where:

 $r_1[,...,r_n]$ 

Specifies that the declared registers (0 through 15) are no longer available for base register assignment.

# **Operational Considerations:**

Registers previously made available for base register assignment may be dropped and made available again in a USING directive. The value assumed to be in a base register may be changed by coding another USING directive without an intervening drop of that register.

DS

#### Function:

Defines storage to be used as work areas, to hold data, and to function as input and output areas. The storage areas are assigned program locations.

#### Format:

| LABEL    | △ OPERATION △ | OPERAND                      |
|----------|---------------|------------------------------|
| [symbol] | DS            | [d] t[L <sub>n</sub> ] ['c'] |

#### where:

#### symbol

Is up to eight characters long.

d

The duplication factor designates the number of identical constants or areas to be generated. An unsigned decimal value is used to specify the duplication factor. If no duplication subfield is used, the assembler assumes a factor of 1. A duplication factor of zero generates neither a constant nor a storage area and, if no length factor is specified, the location counter will provide the proper boundary alignment and assigns the location counter value to the symbol used. A duplication factor of zero is not permitted with literals. Even though the duplication factor can change the size of the storage area used, the use of the duplication factor does not change the length attribute of the field. The maximum value of the duplication factor is 256.

t

The definition-type symbol is required for both DC and DS statements to determine the alignment, padding, truncation, storage form, and implied length. (See Table A—6 for the characteristics of the 13 types used.)

L,

The length factor designates the explicit value of the length attribute of a field generated by a DS or DC statement. The length attribute of a field used in an assembler application instruction determines the number of bytes involved in that instruction. The maximum value of the length factor is 256.

# 'c' or (c)

The constant specification determines the constant, or storage, to be generated. When an apostrophe or ampersand is included in the constant specification, double apostrophes or ampersands are used to indicate the include of these characters in the constant. The constant may take the form of data or an address, as shown in Table A—6.

# NOTE:

The maximum explicit length for a DS is 65,535 bytes. (See Table A—6 for C and X types.) Only the number, not the content, of the bytes reserved by a DS statement is determined by the assembler.

#### Function:

Defines a data storage area permitting one or more programs to use indirect symbolic addressing for the same record items.

#### Format:

| LABEL    | $\Delta$ OPERATION $\Delta$ | OPERAND |
|----------|-----------------------------|---------|
| [symbol] | DSECT                       | unused  |

# Operational Consideration:

Storage is not reserved by a DS directive within a dummy control section, and the data and instructions appearing in a dummy control section do not become part of the assembled program. A separate location counter with an initial value of zero is kept for each dummy control section. More than one DSECT directive with the same symbol may appear in a module. The first DSECT directive initiates the dummy control section; the remaining DSECT directives continue it.

Symbols of statements in a dummy control section are called dummy section symbols. The following rules must be observed in using and assigning dummy section symbols:

- An unpaired dummy section symbol may appear only in an expression defining a storage address for a machine instruction or an S-type constant.
- A base register may not be specified for an address field containing an unpaired dummy section symbol.
- The programmer must ensure that the appropriate value is loaded into the register specified in the USING statement.

To guarantee alignment between the actual storage area and the dummy control section, the user should align the storage area to a double-word boundary.

# **EJECT**

PAGE

Function:

Causes the assembler to continue the assembly listing on the top of the next page.

# Format:

| LABEL  | $\Delta$ OPERATION $\Delta$ | OPERAND |
|--------|-----------------------------|---------|
| unused | EJECT                       | unused  |

# **Operational Considerations:**

If the next line of the listing causes a page change, the EJECT directive has no effect.

When the EJECT directive is encountered, the printing form is skipped to the next page. If a title has been previously specified, the title is printed on the new page. An EJECT directive appearing in a source code macro definition causes the form to be skipped whenever the definition is listed and each time the macro is generated.

The assembler will advance the assembly listing to a new sheet whenever a sheet is full. However, if the programmer would like each new logical part or subroutine to start at the top of a new sheet, he can use the EJECT directive whenever he wants a new sheet to start.

The EJECT directive itself is never printed.

Function:

Indicates the end of a source program.

Format:

| LABEL    | $\Delta$ OPERATION $\Delta$ | OPERAND |
|----------|-----------------------------|---------|
| [symbol] | END                         | [e]     |

where:

е

Is a relocatable expression.

Operational Considerations:

The END directive must be the last statement in the source program. An expression in the operand field designates the point in the program where control may be transferred after the program is loaded.

# **ENTRY**

# Function:

Declares to the assembler those symbols defined by the module being assembled that may be referenced by other modules.

# Format:

| LABEL  | $\Delta$ OPERATION $\Delta$ | OPERAND                 |
|--------|-----------------------------|-------------------------|
| unused | ENTRY                       | symbol[,symbol,,symbol] |

Each symbol in the operand field is declared to be defined in this module. Their names and assigned values are included in the output of the assembler as external reference records.

PAGE

# Function:

Defines the length and value of a symbol using another symbol as all or part of the definition.

# Format:

| LABEL  | $\Delta$ operation $\Delta$ | OPERAND |
|--------|-----------------------------|---------|
| symbol | EQU                         | e[,a]   |

#### where:

- e Is an absolute or relocatable expression.
- Is an absolute expression.

All symbols must be predefined.

# **Operational Considerations:**

The symbol in the label field is defined as the value of the first expression in the operand. The maximum values are  $-2^{23}$  to  $2^{23}-1$ . The length attribute of the symbol is equal to the second expression (a) if explicitly stated. If the second expression (a) is omitted, the symbol will have the length attribute of the first term in the first expression (e). If the first term is an \* or a self-defining term, the length attribute of the symbol is 1.

**EXTRN** 

#### Function:

Declares to the assembler those symbols used in the module being assembled that are defined in a different module.

#### Format:

| LABEL  | $\Delta$ OPERATION $\Delta$ | OPERAND                 |
|--------|-----------------------------|-------------------------|
| unused | EXTRN                       | symbol[,symbol,,symbol] |

# **Operational Considerations:**

Each symbol in the operand field is declared to be a symbol defined in some other module. The symbolic name and the external symbol identification assigned by the assembler are input to the linkage editor as an external definition record. Each reference to the externalized symbol creates an appropriate relocation mask to allow reference resolution at linkage editor time. When an EXTRN and a definition for an identical symbol appear in the same assembly, the EXTRN reference is discarded automatically, and the definition is accepted regardless of the order of appearance of either item.

# **ICTL**

#### Function:

Specifies new values for the begin, end, and continue columns. Normally, a source statement begins in column 1 of the coding form and ends in column 71. If a continuation statement is needed, a character is written in column 72, and the statement continues in column 16 of the following line.

#### Format:

| LABEL  | $\Delta$ OPERATION $\Delta$ | OPERAND       |
|--------|-----------------------------|---------------|
| unused | ICTL                        | [b] [,e] [,c] |

#### where:

- b
  Is an unsigned decimal integer specifying the beginning column. It must be between 1 and 75.
- e Is a unsigned decimal integer specifying the ending column. It must be greater than or equal to  $\mathsf{b}+\mathsf{5}.$
- c
  Is an unsigned decimal integer specifying the continuation column. It must be greater than or equal to b and less than e. The line is continued starting in the column specified by c.

If b is omitted, it is assumed to be 1. If e is omitted, it is assumed to be 71. If c is omitted or if e equals 80, continuation records are not allowed.

#### **Operational Considerations:**

There can be only one ICTL directive in a source code module and it must immediately precede or follow any program-defined macro definitions. The ICTL directive applies only to those source statements that follow it. All library macro definitions are assumed to have normal output format. If the ICTL appears before the START card and it is incorrect, the assembly is terminated. When an ICTL appears out of sequence (must be first statement following START card) the ICTL terminates the assembly.

# Function:

Informs the assembler which columns of the source statement contain the field used for checking the sequence of statements and controls the initiation and termination of sequence checking.

# Format:

| LABEL  | $\Delta$ OPERATION $\Delta$ |     | OPERAND |  |
|--------|-----------------------------|-----|---------|--|
| unused | ISEQ                        | l,r |         |  |
|        |                             |     |         |  |

#### where:

Is a decimal integer specifying the leftmost column of the field to be used for the sequence check.

Is a decimal integer specifying the rightmost column of the field to be used for the sequence check; r must be greater than or equal to I.

# Operational Considerations:

Columns to be checked should not fall between the beginning and ending input columns specified for the program.

The sequence check begins with the first source statement after the first ISEQ directive and is terminated by an ISEQ directive with a blank or invalid operand field.

Sequence checking is not performed on statements generated from macro definitions or on statements inserted into the source code via a COPY directive.

If no ISEQ directive is supplied, no sequence checking occurs.

# **LTORG**

Function:

Generates all literals previously defined into a data pool within the source program.

Format:

| LABEL    | $\Delta$ OPERATION $\Delta$ | OPERAND |
|----------|-----------------------------|---------|
| [symbol] | LTORG                       | unused  |

# **Operational Considerations:**

The literals are pooled following the occurrence of the LTORG directive. A symbol in the label field represents the first byte of the generated literal pool and is assigned a length attribute of 1. LTORG directives may not appear within a dummy control section or in a blank common storage area. If there are no LTORG statements in a program and literals are specified, or if any literals are specified after the last LTORG directive in a program, these literals are pooled at the end of the first control section. The programmer then must ensure that a valid base register is available to address the locations in the literal pool.

Literals are placed in the literal pool according to their total length (duplication factor multiplied by the length of the constant). The literal pool consists of four sections:

- 1. Literals with total lengths that are multiples of double words (eight bytes)
- 2. Literals with total lengths that are multiples of full words (four bytes)
- 3. Literals with total lengths that are multiples of half words
- 4. Any remaining literals

Within each pool section, the literals are stored in order of occurrence. Before the literal pool is generated, the location counter is adjusted to a double-word boundary. If two control sections are assembled together and an LTORG is not included in the second or following sections, then all the literals defined in all the sections will be pooled in the first section and may subsequently be available only to that first section. To ensure that each linked control section can use the literals declared by it, an LTORG can be used within each control section.

**OPSYM** 

#### Function:

The delete operation code (OPSYM) directive allows you to tell the assembler not to accept a certain mnemonic operation code.

# Format:

| LABEL                         | $\Delta$ OPERATION $\Delta$ | OPERAND | _ |
|-------------------------------|-----------------------------|---------|---|
| mnemonic<br>operation<br>code | OPSYM                       | unused  |   |

After you use the OPSYM directive to declare a mnemonic code as unacceptable, the assembler will not generate the normal object code for that mnemonic if it appears after the OPSYM. You are then free to use the declared mnemonic another way, such as the mnemonic code of a macro prototype statement.

The OPSYM directive cannot be used from within a PROC/MACRO or from within code generated as a result of conditional assembly statements.

# **OPSYM**

Example:

|     | LABEL<br>1 | \$ OPERATION \$ | OPERAND<br>16     |
|-----|------------|-----------------|-------------------|
| ١.  |            | MAGRO           |                   |
| 2   |            | A               | &QUANT, &Q2, &SUM |
| 3   |            | L,,,            | 1,3,,&QUANT,      |
| 4.  |            | A               | 1,3,8,92          |
| 5   |            | ST              | 1,3, &sUM         |
| 6   |            | MEND.           |                   |
| 7   |            | SITART          |                   |
| 8.  | Α          | OPS.YM          |                   |
|     |            | •               |                   |
|     |            | •               |                   |
|     |            |                 |                   |
| 9.  | GA,LGHI    | A               | PAY, RAISE, TOTAL |
|     |            |                 |                   |
|     |            |                 |                   |
|     |            |                 |                   |
| lO. |            | END             |                   |
|     |            |                 |                   |

In this example, I preceded my program with a macro definition which I'll use in my program. Line 2 contains the mnemonic code A, which is the mnemonic operation code for an add full word instruction. Before I can call the A macro into my program, I must use an OPSYM directive to tell the assembler not to recognize A as the add full word mnemonic. The OPSYM directive must come before the line of code which references the macro; that is, line 8 must precede line 9.

**ORG** 

PAGE

Function:

Sets or resets the location counter to a specified value.

Format:

| LABEL    | $\Delta$ operation $\Delta$ | OPERAND |
|----------|-----------------------------|---------|
| [symbol] | ORG                         | [e]     |

where:

е

Is a relocatable expression.

# Operational Considerations:

The location counter is set to the value of the expression in the operand field. When no expression is present, the location counter is set to the highest location previously assigned in that control section. A symbol in the label field has the same value as the expression in the operand field and is assigned a length attribute of 1. The expression in the operand field must be relocatable. Its value must represent an address in the same control section in which the ORG occurs. This address value must be equal to or greater than the initial setting of the current location counter. If the expression is in error, the ORG directive is ignored, and the line is flagged. All terms in the expression must be predefined.

The ORG directive permits the location counter to be set to a value not on a half-word boundary.

Bytes of storage reserved with an ORG directive are not set to zero or cleared when the program is loaded.

# PRINT

#### Function:

Controls the contents of the assembly listing.

#### Format:

| LABEL  | $\Delta$ OPERATION $\Delta$ | OPERAND                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |
|--------|-----------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| unused | PRINT                       | [ON ] [ GEN   COUBLE   COUBLE |

#### where:

#### ON

Specifies the listing is to be printed.

#### **OFF**

Specifies that no listing is printed.

# GEN

Specifies that lines generated by a macro instruction are printed.

#### **NOGEN**

Specifies that lines generated by a macro instruction—are not printed, except that the macro instruction and any MNOTE messages generated are printed.

# DATA

Specifies that all characters of each constant representation are printed.

#### **NODATA**

Specifies that only the first eight characters of each constant representation are printed.

# SINGLE

Specifies that the source listing is single-spaced.

#### **DOUBLE**

Specifies that the source listing is double-spaced.

# **Operational Considerations:**

If a PRINT directive specifies OFF plus other parameters, the other specifications are not effective until a PRINT directive is encountered that specifies the listing facility is to be turned ON. The options provided by a PRINT directive are keyword (not positional) parameters; therefore, the comma is not required if a parameter is omitted. The initial print condition of assembly printing is ON, GEN, NODATA, SINGLE. This condition remains until the first PRINT directive changes it. PRINT directives may change from only one to all of the parameters; any unspecified parameters remain in their previous condition. A PRINT directive may not appear in a macro definition.

PAGE

#### Function:

Produces a record at assembly time. This directive is used to produce job control card images to precede or succeed the object module; it eliminates the necessity of manually inserting them.

#### Format:

| LABEL  | $\Delta$ OPERATION $\Delta$ | OPERAND                             |
|--------|-----------------------------|-------------------------------------|
| unused | PUNCH                       | 'c <sub>1</sub> ,,c <sub>80</sub> ' |

#### where:

C<sub>1</sub>,...,C<sub>80</sub>

Represents a string of up to 80 characters produced as a record in the object code output.

# Operational Considerations:

The following conditions apply to characters in the operand field.

- Up to 80 characters, including spaces, may be specified within the apostrophes.
- An apostrophe within the operand must be specified as a pair of apostrophes.
- An ampersand within the operand must be specified as a pair of ampersands.
- Spaces must be used to separate fields.
- In counting the 80 characters, a pair of ampersands or apostrophes written to express a single apostrophe, or ampersand, counts as one.

A PUNCH directive prior to the first control section of the program produces records prior to the first control section, and all others produce records after the last control section.

Variable symbol substitution is performed within the operand field.

Although the PUNCH directive may be included anywhere in the program, it may not be used before macro definitions.

PAGE

# .....

# Function:

Reproduces a record in its entirety (columns 1 through 80) during assembly time. This directive is useful for producing job control card images to precede or succeed the object module and eliminates the necessity of manually inserting them.

#### Format:

| LABEL  | $\Delta$ OPERATION $\Delta$ | OPERAND |
|--------|-----------------------------|---------|
| unused | REPRO                       | unused  |

# Operational Considerations:

This directive causes the contents of the following source record to be reproduced as a record in the assembler output. Each REPRO directive produces one record; up to 80 bytes are reproduced.

A REPRO directive prior to the first control section of the program produces records prior to the first control section, and all others produce records after the last control section.

All REPRO directives following the declaration of the first CSECT (START) produce records which appear after the object module transfer record. Although this directive may be included anywhere in the program, it cannot be used before a macro definition.

No substitution for variable symbols occurs in the record thus produced.

# **SPACE**

PAGE

# Function:

Advances the paper in the printer a specified number of lines. The operand field contains an unsigned decimal integer specifying the number of lines the paper is to be advanced. If no operand is coded, one line will be spaced.

# Format:

| LABEL  | $\Delta$ operation $\Delta$ | OPERAND |
|--------|-----------------------------|---------|
| unused | SPACE                       | [i]     |

where:

i

Is an unsigned decimal integer.

PAGE

# START

Function:

Defines the program name, the name of the first control section, and the initial location counter value.

#### Format:

| LABEL    | $\Delta$ OPERATION $\Delta$ | OPERAND |
|----------|-----------------------------|---------|
| [symbol] | START                       | [a]     |

where:

a

Is an absolute expression.

# Operational Considerations:

A symbol in the label field becomes the name of the first or only control section in the program. If the label field is blank, an unnamed control section is begun. All statements following the START directive are assembled as part of the control section until another unique control section definition is encountered.

The label field of a CSECT directive, which contains the same name as the label field of the START directive, identifies the continuation of the control section. A blank label field in the CSECT directive identifies the continuation of an unnamed control section that began with an unnamed START directive.

The symbol in the label field of the START directive also identifies or names the object program. If the START directive is unnamed, the object module is assigned the name ASMOBJ. The symbol must be a valid symbol. It is an automatic entry point and has a length attribute of 1. The START directive must not be preceded by any statements which would initiate a control section.

The self-defining term in the operand field of the START directive establishes the initial location counter value for the first control section. If the self-defining term represents a value which is not a multiple of 8, the START directive is flagged and the location counter set to the next higher multiple of 8. If the operand is omitted, the initial control section is assigned a location counter value of zero.

PAGE

# Function:

Provides data for the heading of each page of the assembler listing and advances the printer form to a new page.

# Format:

| LABEL  | $\Delta$ OPERATION $\Delta$ |     | OPERAND |
|--------|-----------------------------|-----|---------|
| unused | TITLE                       | 'c' |         |
|        |                             |     |         |

where:

'c'

Is a heading of up to 100 characters enclosed in apostrophes.

# Operational Considerations:

The following conditions apply to characters in the operand field:

- Any character may be specified, including spaces, within the defining apostrophes.
- An apostrophe within the operand must be specified as a pair of apostrophes.
- An ampersand within the operand must be specified as a pair of ampersands.
- Spaces may be specified freely to separate heading words.

More than one TITLE directive is permitted in a program. A TITLE directive provides the heading for all pages in the listing which succeed it.

# USING

#### Function:

Informs the assembler that a specified register is available for base register assignment and will contain a specific value at execution time. The value must be loaded by the program into the base register that the USING directive specifies. The assembler maintains a USING table of the specified registers.

#### Format:

| LABEL  | $\Delta$ OPERATION $\Delta$ | OPERAND                              |
|--------|-----------------------------|--------------------------------------|
| unused | USING                       | v,r <sub>1</sub> [,,r <sub>n</sub> ] |

#### where:

٧

Is the value assumed to be in the first specified register at execution time. This value may be relocatable or absolute. Literals are not permitted.

#### $\mathbf{r}_1[,...,\mathbf{r}_n]$

Specifies that the declared registers (0 through 15) will be used as base registers loaded at execution time. These register numbers do not necessarily have to be assigned in ascending sequence.

# Operational Considerations:

The first register specified after v is assigned the value of v; the next register is assigned the value of the first register plus 4096; the next register is assigned the value of the second register plus 4096; and so on through all the registers specified. A USING directive may specify a single register or a group of registers, or the registers may be specified by individual USING directives.

Register 0 may be specified as a valid base register; however, the assembler assumes that it always contains the value 0 and calculates displacement as if the operand were zero. Register 0 must be the operand specified by  $r_1$ , and any registers specified in the operand field following register 0 are assumed to contain increments of 4096 from zero.

When v is absolute, the indicated registers may be used to process only absolute effective addresses.

When v is relocatable, the indicated registers can be used to process only relocatable effective addresses. The registers  $r_1,...,r_n$  are used to process only those addresses in the same control section as the address represented by v.

The value specification in a USING directive sets the lower limit of an address range; the upper limit is automatically set 4095 bytes above the lower limit. The upper limit of a USING directive may be set less than 4095 bytes by being overlapped by the lower limit of another USING directive.

The range specified by a USING directive is used by the assembler to assign base register and displacement values to those effective operand addresses that fall within that range.

**USING** 

PAGE

If an operand address is specified as an effective address instead of a base register and displacement specification, the assembler searches the USING table for a value yielding a displacement of 4095 or less; if there is more than one such value, the value that yields the smallest displacement is chosen. If no value yields a valid displacement, the operand address is set to zero, and the line is flagged with an error indication. If more than one register contains the value yielding the smallest displacement, the highest numbered register is selected.

| , |  |   |
|---|--|---|
|   |  |   |
|   |  |   |
|   |  |   |
|   |  |   |
|   |  |   |
|   |  |   |
|   |  | • |

4. BAL Macro Definition Statements

# **ACTR**

#### Function:

You use the ACTR statement to limit the number of AGO, AIF, GOTO, AGOB, AIFB, and DO statements that may be processed by the assembler either within a macro or within the source program.

#### Format:

| LABEL  | $\Delta$ OPERATION $\Delta$ | OPERAND         |
|--------|-----------------------------|-----------------|
| unused | ACTR                        | SETA expression |

#### Operational Considerations:

The ACTR statement must be written immediately following the local and global symbol declarations in either the source program or in a macro definition. There can be a separate ACTR statement in the source program and in each macro definition.

The value of the expression in the operand field may be any positive value from 1 to 2<sup>23</sup>—1. The value specified in the operand field causes a counter to be set to that value. This counter is decremented by 1 for each AGO, AGOB, or GOTO statement that is processed for each AIF or AIFB statement whose evaluation resulted in a true condition and for each time that the range of a DO statement is generated.

If prior to decrementing, the counter is zero, the following occurs. If a macro is being processed, its processing and that of any macros above it in a nest are terminated. The next statement to be processed is in the source code following the macro instruction which initiated the nest. If the source code is being processed (outside a macro definition), an END directive is generated. The assembly continues with only that portion of the program generated thus far.

If an ACTR statement is not written, the value of the counter is 4096<sub>16</sub>.

# **AGO**

# Function:

Unconditionally alters the sequence of source statement processing.

# Format:

| LABEL              | $\Delta$ OPERATION $\Delta$ | OPERAND         |
|--------------------|-----------------------------|-----------------|
| [.s <sub>1</sub> ] | AGO AGOB GOTO               | .s <sub>2</sub> |

#### where:

# **AGO**

Defines the operation.

 $.s_1$  Is a sequence symbol.

.s<sub>2</sub>
Is a sequence symbol defined in a following source code statement.

# **Operational Considerations:**

The label field of the AGO statement may contain a sequence symbol. AGOB or GOTO may be used in lieu of AGO in the operation field. The sequence symbol in the operand field is the symbol of the next statement to be processed. Branching forward or backward from the AGO statement is permitted.

When an AGO statement is used in a macro definition, the sequence symbol specified in the operand field must appear in the label field of another statement in that macro definition.

Function:

Conditionally alters the sequence of source statement processing.

#### Format:

| LABEL              | $\Delta$ OPERATION $\Delta$ | OPERAND            |
|--------------------|-----------------------------|--------------------|
| [.s <sub>1</sub> ] | {AIF }                      | (b).s <sub>2</sub> |

where:

.s<sub>1</sub> Is a sequence symbol.

**AIF** 

Defines the operation.

(b) Is a SETB logical expression enclosed in parentheses.

 $.s_2$  Is a sequence symbol defined in a source code statement.

# Operational Considerations:

The label field of the AIF statement may contain a sequence symbol. AIFB is permitted in lieu of AIF in the operation code field.

Any logical expression permitted in the operand field of a SETB statement is valid in the operand field of the AIF statement except a 0 or a 1 enclosed in parentheses. The sequence symbol in the operation field must be written immediately after the parenthesis terminating the logical expression.

If, after the logical expression has been evaluated, the condition is true (a value of 1), you branch to the statement specified by the  $.s_2$  portion of the operand. If the condition is false (a value of 0), the statement in the source code following the AIF statement will be the next statement to be processed. Branching either forward or backward from the AIF statement is permitted. When an AIF statement is written in a macro definition, the sequence symbol specified in the operand field must appear in the label of another statement within that macro definition.

# **ANOP**

#### Function:

Enables branching. If a branch is necessary and no statement within the source code supplies the branch destination in its label field, an ANOP statement can be coded to provide a label to which to branch.

#### Format:

| LABEL | $\Delta$ operation $\Delta$ | OPERAND |
|-------|-----------------------------|---------|
| .s    | { ANOP } LABEL }            | unused  |

# where:

.s

Is a sequence symbol.

# **ANOP**

Defines the operation.

# **Operational Considerations:**

The label field must contain a sequence symbol.

When the label field of a statement which is desired as a branch destination point already contains a symbol or variable symbol, the branch destination is indicated by preceding the statement by an ANOP statement.

LABEL is an acceptable synonym for ANOP in the operation field.

### Function:

Defines the starting point of the code and the numbers of times it is to be generated.

### Format:

| LABEL       | $\Delta$ OPERATION $\Delta$ |   | OPERAND |  |
|-------------|-----------------------------|---|---------|--|
| [&varisymb] | DO                          | а |         |  |

where:

#### &varisymb

Is an optional variable symbol.

DO

Defines the operation.

Is a valid SETA expression or a valid SET expression written in a macro definition in proc format.

### **Operational Considerations:**

The expression in the operand field indicates the number of times the source code statements following the DO statement are produced in the object code. All lines of coding appearing between a DO statement and its associated ENDO statement are generated. The value of the expression in the operand field may be any value from 0 to  $2^{23}$ —1. If the value of the expression is negative, the DO statement is flagged and ignored (that is, treated as if the value has been a 1).

The set of statements between the DO statement and its associated ENDO statement are said to be within the range of the DO statement. Any valid source code statement may be within the range of a DO statement, including other DO statements with their corresponding ENDO statements. DO statements may be nested up to 10 levels.

A variable symbol may be entered in the label field of the DO statement. When the variable symbol in the label field is specified, it is used as a counter for the number of times a set of lines within the range of a DO statement has been generated. The value of this variable symbol is 1 the first time through the set of statements; 2 the second time through; and so forth. It is referenced in the same manner as a SETA symbol.

If a DO statement is within the range of another DO statement and the nested DO statement is reentered, its count begins at 1 again. The value of the variable symbol in the label field of the DO statements is available to the statements following the ENDO statement even if the operation of the DO statement cycle is interrupted.

If an AGO, AGOB, GOTO, AIF, or AIFB statement outside the range of a DO statement results in an assembler branch to a sequence symbol inside the range of the DO statement, processing continues with the statement defining the sequence symbol. Processing proceeds from that point as though the DO statement operand had had a value of 1.

# **END**

Function:

Signifies the end of a macro definition in PROC format.

Format:

| LABEL  | $\Delta$ OPERATION $\Delta$ | OPERAND |
|--------|-----------------------------|---------|
| unused | END                         | unused  |

## **Operational Considerations:**

An END statement signals the end of a macro definition. The assembler pairs each END statement with the most recently encountered unpaired PROC statement. The statements between paired PROC and END statements are defined as the body of a macro definition.

# **ENDO**

Function:

Indicates the end of the range of a DO statement.

Format:

| LABEL  | $\Delta$ OPERATION $\Delta$ | OPERAND |
|--------|-----------------------------|---------|
| unused | ENDO                        | unused  |

## Operational Considerations:

DO and ENDO statements must be paired. For every DO statement, there must be an ENDO statement to define the end of the range.

### Function:

Declares global set symbols. The declarative chosen determines the range of values to which the set symbol may be set and the type of SET statement used to assign the values.

Global set symbols are initialized only once and are used to pass values back and forth between macro definitions. A global set symbol declared at the source code level is available to all macro definitions in which it is also declared.

### Format:

| LABEL  | $\Delta$ OPERATION $\Delta$ | OPERAND                                            |
|--------|-----------------------------|----------------------------------------------------|
| unused | GBL<br>GBLA<br>GBLB<br>GBLC | s <sub>1</sub> [,s <sub>2</sub> ,,s <sub>n</sub> ] |

where:

**GBL** 

Declares a general-purpose global set symbol.

**GBLA** 

Declares an arithmetic global set symbol.

**GBLB** 

Declares a Boolean global set symbol.

**GBLC** 

Declares a character global set symbol.

 $s_1, s_2, \dots, s_n$ 

Are set symbol names.

## **Operational Considerations:**

The operand field of the global set declaration may contain one or more set symbols. A global set symbol is considered defined when declared. It is initialized only once; that is, the first time it is declared. With subsequent declarations in other contexts, the global set symbol is available for use but is not reinitialized. A set symbol must be declared before it is available for use. A set symbol declared by a GBLA or GBLB statement is assigned an initial value of zero. A set symbol declared by a GBLC or GBL statement is assigned an initial value of a null character string.

If a set symbol is declared as a global set symbol in more than one macro definition, it must be declared with the same statement code in each macro definition.

## Function:

Declares local set symbols. The declarative chosen determines the values to which the set symbol may be set and the type of SET statement used to assign the values. A local set symbol is available for use only in the macro definition in which it is declared.

### Format:

| LABEL  | $\Delta$ operation $\Delta$  | OPERAND                                            |
|--------|------------------------------|----------------------------------------------------|
| unused | (LCL<br>LCLA<br>LCLB<br>LCLC | s <sub>1</sub> [,s <sub>2</sub> ,,s <sub>n</sub> ] |

where:

LCL

Declares a general-purpose local set symbol.

**LCLA** 

Declares an arithmetic local set symbol.

**LCLB** 

Declares a Boolean local set symbol.

LCLC

Declares a character local set symbol.

 $s_1, s_2, \dots, s_n$ 

Are set symbol names.

### **Operational Considerations:**

The operand field of the local set declaration may contain one or more set symbol names. A local set symbol is considered defined when declared. A set symbol declared by an LCLA or LCLB statement is assigned an initial value of zero.

A set symbol declared by an LCLC or LCL statement is assigned an initial value of a null character string.

# **MACRO**

## Function:

Designates the start of a macro definition written in macro format.

## Format:

| LABEL  | $\Delta$ OPERATION $\Delta$ | OPERAND |
|--------|-----------------------------|---------|
| unused | MACRO                       | unused  |

## **Operational Considerations:**

This statement may be used only in macro definitions written in macro format.

A macro definition written in macro format consists of the following elements in the order specified:

- 1. MACRO statement (heading)
- 2. Prototype statement (macro instruction format)
- 3. Model statements (optional)
- 4. MEND statement (trailer)

## **Macro Call Instruction**

#### Function:

Causes a precoded set of assembler instructions (a macro definition) to be inserted into a source program at the point where the macro call instruction is located. The macro definition that is inserted into the source program is identified in the operation field of the macro call instruction.

#### Format:

| _ | LABEL    | $\Delta$ OPERATION $\Delta$ | OPERAND                                              |
|---|----------|-----------------------------|------------------------------------------------------|
| _ | [symbol] | call-name                   | [p <sub>1</sub> ,p <sub>2</sub> ,,p <sub>252</sub> ] |
|   |          |                             | ,                                                    |

If a symbol appears in the label field of a macro instruction, it must be explicitly defined in the corresponding macro definition.

The operation field of the macro call instruction contains a symbol which is the name of a macro definition stored in a library or being assembled with the program source code. The operation field calls the desired macro definition. The operand field may contain from 0 through 252 operands separated by commas. Each operand of the macro call instruction is either a positional or keyword parameter that specifies a value which is passed to the corresponding symbolic parameter references in the macro definition.

The value of a positional parameter is identified by the position it holds in the operand field. Given a macro definition which expects four positional parameters to be specified, the operand field of the macro call instruction normally has the form:

 $p_1, p_2, p_3, p_4$ 

An omitted operand must be indicated by writing both commas that separated it from the string.

If the second and third operands are omitted, the form of the operand field of the macro call instruction is:

p<sub>1</sub>,,,p<sub>4</sub>

If the final parameters are the ones to be omitted, the commas following the last operand specified may be dropped. If the macro definition were to be called by using only the second of four parameters, the operand field of the macro call instruction has the form:

,p<sub>2</sub>

## **Macro Call Instruction**

A macro definition may specify that some or all of its parameters are keyword parameters. The specification of a keyword parameter consists of the keyword followed by an equal sign, followed by the value being specified for the parameter. Keyword parameters are separated by commas and may be specified in any order. Consecutive commas are not required to indicate omission of a keyword parameter specification. Keyword parameters have the form:

$$a=b_1,c=d_2,e=f_3$$

or

$$c=d_2,a=b_1,e=f_3$$

A macro definition having both positional and keyword parameters is called a mixed-mode macro definition. The operand field of a mixed-mode macro instruction must contain any positional parameter specifications followed by the keyword parameter specifications being supplied. The last positional parameter specified is followed by a comma followed by the first keyword parameter specification. Mixed-mode parameters have the form:

$$p_1,p_2,p_3,p_4,a=b_1,c=d_2,e=f_3$$

## **Operational Considerations:**

Each of the macro call instruction operands consists of 1 to 127 characters, with the character string satisfying the following conditions:

- May include one or more sequences of characters enclosed in single apostrophes. The apostrophes enclosing each character sequence are paired. Paired apostrophes may appear within paired apostrophes.
- May include a single apostrophe outside paired apostrophes if written as part of the following sequence: any special character except an ampersand, the letter L, an apostrophe, and a letter.
- May include an ampersand as the first character of a variable symbol if the ampersand is a single ampersand or the last ampersand of a string containing an odd number of ampersands.
- May include paired parentheses outside paired apostrophes. To determine pairing, a left parenthesis is paired with the immediately following right parenthesis (that is, no parentheses between them). Additional pairs are determined by ignoring the first pair and reapplying the rule.
- May include an equal sign only as the first character of an operand or within paired parentheses or paired apostrophes.
- May include a comma as a character in a string if the comma is enclosed in paired parentheses or paired apostrophes. A comma standing alone is interpreted as the end of an operand.
- May include a blank within paired apostrophes. A blank not enclosed in apostrophes terminates the operand field.

### NOTE:

Operands can be coded on more than one line through the use of a continuation character in column 72. If a line is to be continued, the last operand on that line must be followed by a comma. A warning message is issued if a comma is not included.

**MEND** 

Function:

Signifies the end of a macro definition written in macro format.

Format:

| LABEL  | $\Delta$ operation $\Delta$ | OPERAND |
|--------|-----------------------------|---------|
| unused | MEND                        | unused  |

## **Operational Considerations:**

This statement is allowed only once in each macro definition, and it must be the last statement of the definition.

## Function:

Indicates to the assembler that thy processing of a macro definition should be terminated before ending normally with a MEND statement. This statement is used when it is necessary to process only one section or operation of a macro definition rather than the entire macro definition.

### Format:

| LABEL  | $\Delta$ OPERATION $\Delta$ | OPERAND |
|--------|-----------------------------|---------|
| unused | MEXIT                       | unused  |

## Operational Considerations:

When MEXIT is encountered, the assembler terminates processing the macro definition and processes the statement in the source program following the macro call instruction that called the macro definition containing the MEXIT.

A second macro instruction with different operands may request the processing of different portions of the macro definition containing the MEXIT.

## Function:

Generates an error message, which indicates how dangerous an error is, or to generate a comment, which supplies information. An MNOTE statement is used in a macro definition or in source code statements.

### Format:

| LABEL  | $\Delta$ operation $\Delta$ | OPERAND                                                       |
|--------|-----------------------------|---------------------------------------------------------------|
| unused | MNOTE                       | ( 'm' )<br>\( \Delta, 'm' \)<br>\( \S, 'm' \)<br>\( *, 'm' \) |

In this format, you can specify: a message enclosed in apostrophes, a comma followed by a message enclosed in apostrophes, a severity code followed by a message, or an asterisk followed by a message. In all cases, the message is printed in the assembly listing source code. The severity code indicates the danger of the error which occurred. The severity code is a decimal value of 0 to 255. If you want to indicate a severity code of 1, you leave a blank space ( $\triangle$ ) followed by the error message, enclosed in apostrophes. An asterisk used as the severity code indicates that the message following it is informational and not an error. As mentioned before, any of these specifications causes the message to be printed in the assembly listing. Also, MNOTE lines are flagged as errors and listed in the diagnostics portion of the assembly listing if they don't have an asterisk in operand 1. Messages which are preceded by an asterisk are not flagged or listed in the diagnostics because they are not errors.

Variable symbols can be used as operands in an MNOTE statement.

## **Model Statement**

## Function:

Model statements are between the NAME and END statements in a proc and between the prototype and MEND statements in a macro. The model statements define the pattern of operations to be performed at assembly. Model statements do not generate object code.

### Format:

|                       | LABEL                            | $\Delta$ OPERATION $\Delta$ |          | OPERAND |  |
|-----------------------|----------------------------------|-----------------------------|----------|---------|--|
| varia<br>sequ<br>symi | ble symbol<br>ence symbol<br>pol | mnemonic code               | operands |         |  |

## **Operational Considerations:**

The label field cannot contain an asterisk.

The operation field can contain the mnemonic operation code of an assembler instruction, directive, or macro definition. The field can also contain a variable symbol if you want to generate a different operation each time the macro is called. The variable symbol is restricted to seven characters, preceded by an ampersand. The operation field cannot contain the mnemonic codes END, ICTL, ISEQ, or PRINT.

The operand field can contain symbols or variable symbols. The size of the field, after the variable values are substituted, is up to 240 characters.

## **NAME**

#### Function:

Supplies the mnemonic operation code by which a macro definition in proc format is referenced. The label field of this statement supplies the name of the macro definition in which it appears.

#### Format:

| LABEL     | $\Delta$ OPERATION $\Delta$ | OPERAND |
|-----------|-----------------------------|---------|
| call-name | NAME                        | pos-0   |

The call-name symbol in the label field of the NAME statement identifies the mnemonic operation code by which the macro definition may be referenced. This symbol must be unique; it may not be the same as the mnemonic operation code of a machine, assembler directive, or assembler instruction or duplicate the mnemonic operation code associated with any other macro definition in the source program.

In the operand field, pos-0 can be a decimal or alphanumeric value but it cannot be a variable symbol. The value in the operand field of the NAME statement is referenced as positional parameter 0 by using the same symbolic parameter you indicated in operand 1 of the PROC statement. You can vary the value for positional parameter 0 by using multiple NAME statements.

## Operational Considerations:

At least one NAME statement is required for each macro definition, but more than one may be written. Each NAME statement specifies a different name (symbol) by which the macro definition may be referenced. The NAME statement must be written immediately after the PROC statement. When more than one NAME statement follows the PROC statement, only the operand of the NAME statement containing the symbol used to reference the macro definition is available to the body of the definition.

Multiple NAME statements allow the programmer to specify a different parameter for each NAME statement and to select the parameter by referencing that particular NAME statement.

## **PNOTE**

Function:

Generates an error message or a comment. A PNOTE statement is used in a macro definition or a source code statement.

Format:

| LABEL  | $\Delta$ OPERATION $\Delta$ | OPERAND        |
|--------|-----------------------------|----------------|
| unused | PNOTE                       | { * 'e'} , 'm' |

In this format, there are two operand fields. In the first field, you can specify an asterisk to indicate that the message is informational and not an error, or you can specify a character expression containing up to six characters. The second operand field contains the message. It can contain up to 79 characters. Regardless of the choice you make for the first operand, the message is printed in the assembly listing source code. If it does not contain an asterisk as operand 1, a PNOTE statement is flagged as an error, and listed in the diagnostics portion of the assembly listing. If there is an asterisk in the first operand field, the line is not flagged or listed in diagnostics. This is done because asterisk indicates that the message is not an error.

Variable symbols can be used as operands in a PNOTE statement.

**PROC** 

Function:

Designates the start of a macro definition written in proc format.

### Format:

| $\Delta$ OPERATION $\Delta$ | OPERAND                                              |
|-----------------------------|------------------------------------------------------|
| PROC                        | [&pos,n] [,&key <sub>1</sub> =,,&key <sub>m</sub> =] |
|                             |                                                      |

where:

#### &symbol

Is a variable symbol referring to the label of the macro instruction.

## &pos,n

Is a variable symbol used in the body of the PROC to reference positional parameters in the call instruction. The n is a decimal number indicating how many positional parameters there are.

## $& \text{key}_1 = , ..., & \text{key}_m =$

Specifies the keyword parameters. (If only keyword parameters are specified, commas must be coded in operands 1 and 2.)

## Operational Considerations:

A macro definition written in proc format consists of the following elements in the order specified.

- PROC statement (heading) 1.
- 2. NAME statements
- 3. Model statements (optional)
- 4. END statement (trailer)

Macro definitions may contain either a macro or a proc format within a definition, but not both.

## **PROC**

The functions of the PROC statement are:

- to designate the beginning of a macro definition;
- to identify the variable symbol if any, that refers to the label of the macro instruction;
- to specify the maximum number of positional parameters in the macro instruction calling a macro definition;
- to identify the variable symbols to be used to address the positional and keyword parameters in the operand field of the macro instruction; and
- to optionally specify a default value for each keyword. Values assigned to keyword parameters are set to null if nothing follows the equal sign. If a default setting is provided, the respective keyword is set to that value when the proc is called. The setting then remains unchanged if the keyword is not specified with an appropriate value on the call line.

# **Prototype Statement**

### Function:

Provides the mnemonic operation code by which a macro instruction may call a macro definition written in macro format. It names the macro definition. The prototype statement specifies the names of the positional parameters in the macro instruction that call the macro definition containing the prototype statement.

#### Format:

| LABEL   | $\Delta$ OPERATION $\Delta$ | OPERAND                                                                         |
|---------|-----------------------------|---------------------------------------------------------------------------------|
| &symbol | call-name                   | &pos <sub>1</sub> ,,&pos <sub>n</sub> ,&key <sub>1</sub> =,,&key <sub>m</sub> = |

#### where:

### &symbol

Is a variable symbol that refers to the symbol in the label field of the macro call instruction.

### call-name

Is the symbol that is the name of the macro definition.

## &pos<sub>1</sub>,...,&pos<sub>n</sub>

Are variable symbols used as positional parameters.

$$&\text{key}_1 = ,..., &\text{key}_m =$$

Are variable symbols used as keyword parameters.

## **Operational Considerations:**

If the label field of the prototype statement is blank, or if the variable symbol specified does not also appear in the label field of a model statement generated by the macro definition, the symbol in the label field of the macro instruction will not be defined when the macro is generated. This symbol must not duplicate the name of any parameter or set symbol defined within the prototype statement.

The operand field of the prototype statement contains the names of all the symbolic parameters wich may be coded for the macro. Zero through 252 positional and keyword parameters are permitted in the operand field. If the macro instruction contains a mixture of both positional and keyword parameters, the names of all the positional parameters must precede the names of the keyword parameters. The names of the positional parameters must appear in the order specified in the operand field of each macro call instruction.

Within the operand field of the prototype statement, the entry defining a positional parameter consists entirely of the variable symbol that names the parameter. The entry for a keyword parameter consists of the variable symbol naming the parameter followed by an equal sign. The equal sign may be optionally followed by a string of characters specifying a default value for that parameter. If no specification for the parameter is supplied in the macro call instruction, the default value is the value supplied for a reference to that parameter within a macro definition. The default value must be written following the rules for macro instruction operands. As many continuation lines may be used as required to contain the symbolic parameters and the desired comments.

## SET

### Function:

Assigns either an arithmetic or character string value to a variable symbol declared by an LCL or GBL statement.

#### Format:

| LABEL | $\Delta$ OPERATION $\Delta$ |                | OPERAND |  |
|-------|-----------------------------|----------------|---------|--|
| &s    | SET                         | ${a \brace c}$ |         |  |

### where:

&s

Is a set symbol declared by LCL or GBL.

SET

Defines the operation.

а

Is a valid arithmetic expression.

С

Is a valid character expression.

## **Operational Considerations:**

When the operand of the SET statement contains an arithmetic expression, the value of the expression may range from  $-2^{23}$  to  $+2^{23}-1$ . When the operand of the SET statement contains a character expression, the maximum length that may be specified is eight characters.

If a SET variable symbol is assigned a character value, a reference to the SET symbol yields the same result as a reference to SETC symbol assigned the same character value. Similarly, if a SET variable symbol is assigned an arithmetic value, a reference to the SET symbol yields the same result as a reference to a SETA symbol assigned the same value. A SET variable symbol with a character value may be reassigned an arithmetic value, and vice versa.

A SET expression is a SETA expression allowing the use of the operators >, <,=, \*\*, and ++ in the SET expression when an arithmetic operator is valid. The characters \*\* represent the logical product AND, and the characters ++ represent the logical sum OR.

SET

Each bit of the first term is compared with its corresponding bit in the second term, and the result of the comparison is placed in the corresponding position in the resulting term. The result of the bit comparison for each operator is:

| AND      |   |        |  |  |
|----------|---|--------|--|--|
| <br>A**B |   | Result |  |  |
| 1        | 1 | 1      |  |  |
| 1        | 0 | 0      |  |  |
| 0        | 1 | 0      |  |  |
| 0        | 0 | 0      |  |  |
|          |   |        |  |  |

<

| OR |     |        |  |  |
|----|-----|--------|--|--|
| Α- | ++B | Result |  |  |
| 1  | 1   | 1      |  |  |
| 1  | 0   | 1      |  |  |
| 0  | 1   | 1      |  |  |
| 0  | 0   | 0      |  |  |
|    |     |        |  |  |

The three relational operators are the equal (=) operator, the greater than (>) operator, and the less than (<) operator:

Compares the value of two terms or expressions. If the two values are equal, the assembler assigns a value of 1 to the expression. If the values are not equal, a zero value is assigned.

Compares two terms or expressions. If the value of the first (left) term is greater than the value of the second (right) term, a value of 1 is assigned to the expression. If the value of the second term is greater than the value of the first term, a zero value is assigned.

Compares the value of the first (left) expression or term with the second (right) expression or term. If the value of the first expression or term is less than the value of the second, a value of 1 is assigned to the expression. If the value of the second expression or term is less than the value of the first, a zero value is assigned.

Given the expression A+B > C, if the expression A+B has a greater value than the value of C, the assembler assigns a value of 1 to the expression. If the value of C is greater than the value of A+B, a zero value is assigned.

Since the value of a relational or logical expression is arithmetic, the expression may be used as a term in an arithmetic expression. The following chart shows operator priority.

| Operator | Hierarchy |  |
|----------|-----------|--|
| *,/      | 5         |  |
| +,—      | 4         |  |
| . **     | 3         |  |
| ++       | 2         |  |
| <>=      | 1         |  |
|          |           |  |

Four statements are provided to assign values to set symbols: SETA, SETB, SETC, and SET. The statement used depends on the statement chosen to declare the set symbol. SETA, SETB, and SETC statements may be used only within macro definitions written in macro format. The SET statement may be used only within macro definitions written in proc format.

## SETA

### Function:

Assigns an arithmetic value to a variable symbol that was declared by an LCLA or GBLA statement.

### Format:

| LABEL | $\Delta$ OPERATION $\Delta$ | OPERAND |
|-------|-----------------------------|---------|
| &s    | SETA                        | а       |

#### where:

&s

а

Is a set symbol declared by either LCLA or GBLA.

#### **SETA**

Defines the operation.

Is a valid SETA term or an arithmetic combination of valid SETA terms.

## **Operational Considerations:**

### A valid SETA term is:

- a self-defining term; or
- a variable symbol with an arithmetic value; or
- a character value consisting of one to eight decimal digits.

The arithmetic operators used in writing SETA expressions are +, -, \*, and /. The expression may not begin with an operator. Two operators or two terms may not succeed one another.

The rules of precedence for the evaluation of a SETA arithmetic expression are the same as stated for a SET statement. The value of a SETA expression may range from  $-2^{23}$  to  $2^{23}-1$ .

When the SETA symbol is used in an arithmetic expression, the arithmetic value of the symbol is substituted for the symbol. If the SETA symbol is used in another context, the arithmetic value of the SETA symbol is converted to a decimal integer with leading zeros removed. A leading minus sign will be retained. This decimal value is then substituted for the SETA symbol. If the value of the SETA symbol is zero, a single zero is substituted.

Four statements are provided to assign values to set symbols: SETA, SETB, SETC, and SET. The statement used depends on the statement chosen to declare the set symbol. SETA, SETB, and SETC statements may be used only within macro definitions written in macro format. The SET statement may be used only within macro definitions written in proc format.

## **SETB**

#### Function:

Assigns a binary value of 0 or 1 to a variable symbol which was declared by an LCLB or GBLB statement.

#### Format:

| LABEL | $\Delta$ OPERATION $\Delta$ | OPERAND |
|-------|-----------------------------|---------|
| &s    | SETB                        | b       |

#### where:

&s

Is a set symbol declared in either LCLB or GBLB.

### **SETB**

Defines the operation.

b

Is a valid logical expression, a 0 or a 1, that must be enclosed in parentheses.

## **Operational Considerations:**

The logical expression in the operand field may have a value of either 0 (false) or 1 (true), and the set symbol specified in the name field of the set statement is assigned the resultant binary value. The logical expression may consist of a single term or logical combination of terms.

The permissible terms are:

- a SETB arithmetic relational expression;
- a SETB character relational expression; and
- a SETB symbol.

The SETB logical operators that may be used to combine the terms are [10], [10], and [10]. The logical expression must not contain two terms in succession. Two operators may appear in succession if the first operator is either [10] or [10], and the second operator is [10]. Only the operator [10] is allowed prior to the first term of the expression.

**SETB** 

A SETB arithmetic relational expression consists of two arithmetic expressions connected by a SETB relational operator. A SETB character relational expression consists of two character strings connected by a SETB relational operator. The SETB relational operators are:

| Operator | Meaning               |
|----------|-----------------------|
| NE       | Not equal             |
| EQ       | Equal                 |
| LT       | Less than             |
| LE       | Less than or equal    |
| GT       | Greater than          |
| GE       | Greater than or equal |

The arithmetic expression that may be used as a term in the SETB arithmetic relational expression is defined under the SETA statement. The rules under the SETC statement define the format of the character string that may be used in a SETB character relational expression. If two character strings are of unequal length, the shorter will always compare less than the longer, regardless of actual value. The maximum length of character strings that may be compared is 127 characters.

In writing SETB expressions, the SETB relational or logical operators must be preceded and followed by at least one blank or other special character. The relational expression may be optionally enclosed in parentheses.

The procedure for evaluating a SETB expression is:

- Each term (SETB symbol, SETB arithmetic expression, or SETB character expression) is evaluated and given a value of either 1 (true) or 0 (false).
- Evaluation is from left to right. The weight of the logical operators is:

$$= 1$$

$$MD = 2$$

$$xoz = 3$$

Therefore, III is performed prior to III, and III is performed prior to III.

If a SETB variable symbol is used in the operand field of a SETA or DO statement, or in an arithmetic relation (in either a SETB or AIF term), the binary values 0 and 1 are converted to the arithmetic values  $\pm 0$  and  $\pm 1$ .

If the SETB variable symbol is used in the operand field of a SET statement, the value substituted is dependent on the context. In an arithmetic expression, +1 or +0 is substituted. In a character expression, the character values 1 and 0 are substituted.

AGE

# **SETB**

Four statements are provided to assign values to set symbols: SETA, SETB, SETC, and SET. The statement used depends on the statement chosen to declare the set symbol. SETA, SETB, and SETC statements may be used only within macro definitions written in macro format. The SET statement may be used only within macro definitions written in proc format.

### Function:

Assigns a character value to a variable symbol that was declared by an LCLC of GBLC statement.

### Format:

| LABEL | $\Delta$ OPERATION $\Delta$ | OPERAND |
|-------|-----------------------------|---------|
| &s    | SETC                        | С       |

## where:

&s

Is a set symbol declared by either LCLC or GBLC.

## **SETC**

Defines the operation.

С

Is a valid SETC operand.

## Operational Considerations:

A SETC operand must be a character expression.

The maximum length of the value that may be specified for a SETC symbol is eight characters. If more than eight characters are specified, only the leftmost eight characters are used by the assembler.

Four statements are provided to assign values to set symbols: SETA, SETB, SETC, and SET. The statement used depends on the statement chosen to declare the set symbol. SETA, SETB, and SETC statements may be used only within macro definitions written in macro format. The SET statement may be used only within macro definitions written in proc format.

Appendix A. Assembler References

Table A-1. Instruction Formats (Part 1 of 2)

| landania d          | Source Code Instruction Format                                                                                    |                                                                                                     | Object Code Instruction Format |                    |                |                      |                                    |                |                                             |    |
|---------------------|-------------------------------------------------------------------------------------------------------------------|-----------------------------------------------------------------------------------------------------|--------------------------------|--------------------|----------------|----------------------|------------------------------------|----------------|---------------------------------------------|----|
| Instruction<br>Type | Explicit Form                                                                                                     | Implicit Form                                                                                       | Byte 1                         | Half Word Byte 2   |                | 16 19                | Second Half Word  Bytes 3 and 4 20 | 31 32 3        | Third Half Word<br>Bytes 5 and 6<br>35   36 | 47 |
| RR                  | [symbol] opcode r <sub>1</sub> ,r <sub>2</sub>                                                                    | [symbol] opcode r <sub>1</sub> ,r <sub>2</sub>                                                      | 1                              |                    | reg<br>op 2    |                      |                                    |                |                                             |    |
|                     |                                                                                                                   |                                                                                                     | opcode                         | r <sub>1</sub>     | r <sub>2</sub> |                      |                                    |                |                                             |    |
| RX                  | [symbol] opcode r <sub>1</sub> ,d <sub>2</sub> (x <sub>2</sub> ,b <sub>2</sub> )                                  | [symbol] opcode r <sub>1</sub> ,s <sub>2</sub> (x <sub>2</sub> )                                    |                                | reg<br>op 1        |                | address<br>operand 2 |                                    |                |                                             |    |
|                     |                                                                                                                   |                                                                                                     | opcode                         | r,                 | × <sub>2</sub> | b <sub>2</sub>       | d <sub>2</sub>                     |                |                                             |    |
| RS                  | [symbol] opcode r <sub>1</sub> , r <sub>3</sub> ,d <sub>2</sub> (b <sub>2</sub> ) (3)                             | [symbol] opcode r <sub>1</sub> ,r <sub>3</sub> ,s <sub>2</sub>                                      |                                | reg<br>op 1        | reg<br>op 3    |                      | address<br>operand 2               |                |                                             |    |
|                     |                                                                                                                   |                                                                                                     | opcode                         | ۲,                 | r <sub>3</sub> | b <sub>2</sub>       | d <sub>2</sub>                     |                |                                             |    |
| SI                  | [symbol] opcode d <sub>1</sub> (b <sub>1</sub> ),i <sub>2</sub>                                                   | [symbol] opcode s <sub>1</sub> ,i <sub>2</sub>                                                      |                                | immedi             |                |                      | address<br>operand 1               |                |                                             |    |
|                     |                                                                                                                   |                                                                                                     | opcode                         | i <sub>2</sub>     |                | b,                   | d,                                 | 7              |                                             |    |
|                     | [symbol] opcode d <sub>1</sub> (I,b <sub>1</sub> ),d <sub>2</sub> (b <sub>2</sub> )                               | [symbol] opcode s <sub>1</sub> (I),s <sub>2</sub>                                                   |                                | length<br>op 1 and | ор 2           |                      | address<br>operand 1               |                | address<br>operand 2                        |    |
|                     |                                                                                                                   |                                                                                                     | opcode                         | I-1                |                | b,                   | d <sub>1</sub>                     | b <sub>2</sub> | d <sub>2</sub>                              | -  |
| SS                  | [symbol] opcode d <sub>1</sub> (I <sub>1</sub> ,b <sub>1</sub> ),d <sub>2</sub> (I <sub>2</sub> ,b <sub>2</sub> ) | ,b <sub>2</sub> ) [symbol] opcode s <sub>1</sub> (l <sub>1</sub> ),s <sub>2</sub> (l <sub>2</sub> ) |                                | length<br>op 1     | op 2           |                      | address<br>operand 1               |                | address<br>operand 2                        |    |
|                     |                                                                                                                   |                                                                                                     | opcode                         | 1,-1               | 12-1           | ь,                   | d <sub>1</sub>                     | b <sub>2</sub> | d <sub>2</sub>                              |    |

## NOTES:

- The RR instruction has three other forms:

  [symbol] opcode i<sub>1</sub> for the SVC instruction;

  [symbol] opcode r<sub>1</sub> for the SPM instruction; and

  [symbol] opcode m<sub>1</sub>, r<sub>2</sub> for the BCR instruction.
- The RX instruction BC is written in the form:

  [symbol] opcode m<sub>1</sub>, d<sub>2</sub> (x<sub>2</sub>, b<sub>2</sub>)

- $\begin{tabular}{ll} \hline \textbf{(3)} & The RS shift instructions are written without use of the $r_3$ operand, in the form: \\ & [symbol] opcode $r_1$, $d_2$($b_2$) \\ \hline \end{tabular}$
- Some SI instructions, such as TS, SSM, and SIO, do not use an  $i_2$  field. They are written in the form: [symbol] opcode  $d_1(b_1)$

Table A-1. Instruction Formats (Part 2 of 2)

| Characters      | Meaning                                                                                           |
|-----------------|---------------------------------------------------------------------------------------------------|
| OPCODE          | The application instruction operation code.                                                       |
| r <sub>1</sub>  | The number of the general register containing operand 1                                           |
| r <sub>2</sub>  | The number of the general register containing operand 2                                           |
| r <sub>3</sub>  | The number of the general register containing operand 3                                           |
| x <sub>2</sub>  | The number of the general register containing an index number for operand 2 of the RX instruction |
| i <sub>1</sub>  | The immediate data used as operand 1 of the SVC instruction                                       |
| i <sub>2</sub>  | The immediate data used as operand 2 of an SI instruction                                         |
| 1               | The length of the operands as stated in source code*                                              |
| 1,              | The length of operand 1 as stated in source code*                                                 |
| l <sub>2</sub>  | The length of operand 2 as stated in source code*                                                 |
| b <sub>1</sub>  | The number of the general register containing the base address for operand 1                      |
| b <sub>2</sub>  | The number of the general register containing the base address for operand 2                      |
| d <sub>1</sub>  | The displacement for the base address of operand 1                                                |
| d <sub>2</sub>  | The displacement for the base address of operand 2                                                |
| m <sub>1</sub>  | The mask used as operand 1                                                                        |
| op <sub>1</sub> | Operand 1                                                                                         |
| op <sub>2</sub> | Operand 2                                                                                         |
| op <sub>3</sub> | Operand 3                                                                                         |
| s <sub>1</sub>  | The symbol used to identify operand 1 in the implicit format                                      |
| s <sub>2</sub>  | The symbol used to identify operand 2 in the implicit format                                      |

<sup>\*</sup>This is coded as the true source code length of the operand, not the length less 1, as assembled in the object code. The assembler makes a reduction of 1 in the length when converting source code to object code.

| Listing By Mnemonic Code |                              |                 |                |                                                                                                   |                                                                   |  |
|--------------------------|------------------------------|-----------------|----------------|---------------------------------------------------------------------------------------------------|-------------------------------------------------------------------|--|
| Mnemonic                 | Instruction Name             | Machine<br>Code | Byte<br>Length | Source Code Format                                                                                |                                                                   |  |
| Willemonic               | mstraction (varie            |                 |                | Explicit                                                                                          | Implicit                                                          |  |
| Α                        | Add                          | 5A              | 4              | r <sub>1</sub> ,d <sub>2</sub> (x <sub>2</sub> ,b <sub>2</sub> )                                  | r <sub>1</sub> s <sub>2</sub> (x <sub>2</sub> )                   |  |
| AD*                      | Add normalized, long         | 6A              | 4              | r <sub>1</sub> ,d <sub>2</sub> (x <sub>2</sub> ,b <sub>2</sub> )                                  | r <sub>1</sub> ,s <sub>2</sub> (x <sub>2</sub> )                  |  |
| ADR*                     | Add normalized, long         | 2A              | 2              | r <sub>1</sub> ,r <sub>2</sub>                                                                    | r <sub>1</sub> ,r <sub>2</sub>                                    |  |
| AE*                      | Add normalized, short        | 7A              | 4              | r <sub>1</sub> ,d <sub>2</sub> (x <sub>2</sub> ,b <sub>2</sub> )                                  | r <sub>1</sub> ,s <sub>2</sub> (x <sub>2</sub> )                  |  |
| AER*                     | Add normalized, short        | 3A              | 2              | r <sub>1</sub> ,r <sub>2</sub>                                                                    | r <sub>1</sub> ,r <sub>2</sub>                                    |  |
| AH                       | Add half word                | 4A              | 4              | r <sub>1</sub> ,d <sub>2</sub> (x <sub>2</sub> ,b <sub>2</sub> )                                  | r <sub>1</sub> ,s <sub>2</sub> (x <sub>2</sub> )                  |  |
| ΑI                       | Add immediate                | 9A              | 4              | d <sub>1</sub> (b <sub>1</sub> ),i <sub>2</sub>                                                   | s <sub>1</sub> ,i <sub>2</sub>                                    |  |
| AL*                      | Add logical                  | 5E              | 4              | r <sub>1</sub> ,d <sub>2</sub> (x <sub>2</sub> ,b <sub>2</sub> )                                  | r <sub>1</sub> ,s <sub>2</sub> (x <sub>2</sub> )                  |  |
| ALR*                     | Add logical                  | 1E              | 2              | r <sub>1</sub> ,r                                                                                 | r <sub>1</sub> ,r <sub>2</sub>                                    |  |
| AP                       | Add decimal                  | FA              | 6              | d <sub>1</sub> (I <sub>1</sub> ,b <sub>1</sub> ),d <sub>2</sub> (I <sub>2</sub> ,b <sub>2</sub> ) | s <sub>1</sub> (1 <sub>1</sub> ),s <sub>2</sub> (1 <sub>2</sub> ) |  |
| AR                       | Add                          | 1A              | 2              | r <sub>1</sub> ,r <sub>2</sub>                                                                    | r <sub>1</sub> ,r <sub>2</sub>                                    |  |
| AU*                      | Add unnormalized, short      | 7E              | 4              | r <sub>1</sub> ,d <sub>2</sub> (x <sub>2</sub> ,b <sub>2</sub> )                                  | r <sub>1</sub> ,s <sub>2</sub> (x <sub>2</sub> )                  |  |
| AUR*                     | Add unnormalized, short      | 3E              | 2              | r <sub>1</sub> ,r <sub>2</sub>                                                                    | r <sub>1</sub> ,r <sub>2</sub>                                    |  |
| AW*                      | Add unnormalized, long       | 6E              | 4              | r <sub>1</sub> ,d <sub>2</sub> (x <sub>2</sub> ,b <sub>2</sub> )                                  | r <sub>1</sub> ,s <sub>2</sub> (x <sub>2</sub> )                  |  |
| AWR*                     | Add unnormalized, long       | 2E              | 2              | r <sub>1'</sub> r <sub>2</sub>                                                                    | r <sub>1</sub> ,r <sub>2</sub>                                    |  |
| BAL                      | Branch and link              | 45              | 4              | r <sub>1</sub> ,d <sub>2</sub> (x <sub>2</sub> ,b <sub>2</sub> )                                  | r <sub>1</sub> ,s <sub>2</sub> (x <sub>2</sub> )                  |  |
| BALR                     | Branch and link              | 05              | 2              | r <sub>1</sub> ,r <sub>2</sub>                                                                    | r <sub>1</sub> ,r <sub>2</sub>                                    |  |
| BAS                      | Branch and store             | 4D              | 4              | ( compatibility )                                                                                 | ' -                                                               |  |
| BASR                     | Branch and store             | 0D              | 2              | mode only                                                                                         |                                                                   |  |
| вс                       | Branch on condition          | 47              | 4              | i,d <sub>2</sub> (x <sub>2</sub> ,b <sub>2</sub> )                                                | i,s <sub>2</sub> (x <sub>2</sub> )                                |  |
| BCR                      | Branch on condition          | 07              | 2              | i,r <sub>2</sub>                                                                                  | i,r <sub>2</sub>                                                  |  |
| BCT                      | Branch on count              | 46              | 4              | r <sub>1</sub> ,d <sub>2</sub> (x <sub>2</sub> ,b <sub>2</sub> )                                  | r <sub>1</sub> ,s <sub>2</sub> (x <sub>2</sub> )                  |  |
| BCTR                     | Branch on count              | 06              | 2              | r <sub>1'</sub> r <sub>2</sub>                                                                    | r <sub>1</sub> ,r <sub>2</sub>                                    |  |
| BXH*                     | Branch on index high         | 86              | 4              | r <sub>1</sub> ,r <sub>3</sub> ,d <sub>2</sub> (b <sub>2</sub> )                                  | r <sub>1</sub> ,r <sub>3</sub> ,s <sub>2</sub>                    |  |
| BXLE*                    | Branch on index low or equal | 87              | 4              | r <sub>1</sub> ,r <sub>3</sub> ,d <sub>2</sub> (b <sub>2</sub> )                                  | r <sub>1</sub> ,r <sub>3</sub> ,s <sub>2</sub>                    |  |
| С                        | Compare algebraic            | 59              | 4              | r <sub>1</sub> ,d <sub>2</sub> (x <sub>2</sub> ,b <sub>2</sub> )                                  | r <sub>1</sub> ,s <sub>2</sub> (x <sub>2</sub> )                  |  |
| CD*                      | Compare, long                | 69              | 4              | r <sub>1</sub> ,d <sub>2</sub> (x <sub>2</sub> ,b <sub>2</sub> )                                  | r <sub>1</sub> ,s <sub>2</sub> (x <sub>2</sub> )                  |  |
| CDR*                     | Compare, long                | 29              | 2              | r <sub>1'</sub> r <sub>2</sub>                                                                    | r <sub>1</sub> ,r <sub>2</sub>                                    |  |
| CE*                      | Compare, short               | 79              | 4              | r <sub>1</sub> ,d <sub>2</sub> (x <sub>2</sub> ,b <sub>2</sub> )                                  | r <sub>1</sub> ,s <sub>2</sub> (x <sub>2</sub> )                  |  |
| CER*                     | Compare, short               | 39              | 2              | r <sub>1'</sub> r <sub>2</sub>                                                                    | r <sub>1</sub> ,r <sub>2</sub>                                    |  |
| СН                       | Compare half word            | 49              | 4              | r <sub>1</sub> ,d <sub>2</sub> (x <sub>2</sub> ,b <sub>2</sub> )                                  | r <sub>1</sub> ,s <sub>2</sub> (x <sub>2</sub> )                  |  |
| CL                       | Compare logical              | 55              | 4              | r <sub>1</sub> ,d <sub>2</sub> (x <sub>2</sub> ,b <sub>2</sub> )                                  | r <sub>1</sub> ,s <sub>2</sub> (x <sub>2</sub> )                  |  |
| CLC                      | Compare logical              | D5              | 6              | d <sub>1</sub> ,(I,b <sub>1</sub> ),d <sub>2</sub> (b <sub>2</sub> )                              | s <sub>1</sub> (I),s <sub>2</sub>                                 |  |
| CLI                      | Compare logical immediate    | 95              | 4              | d <sub>1</sub> (b <sub>1</sub> ),i <sub>2</sub>                                                   | s <sub>1</sub> ,i <sub>2</sub>                                    |  |
| CLR                      | Compare logical              | 15              | 2              | r <sub>1</sub> ,r <sub>2</sub>                                                                    | r <sub>1</sub> ,r <sub>2</sub>                                    |  |
| СР                       | Compare decimal              | F9              | 6              | d <sub>1</sub> (l <sub>1</sub> ,b <sub>1</sub> ),d <sub>2</sub> (l <sub>2</sub> ,b <sub>2</sub> ) | s <sub>1</sub> (l <sub>1</sub> ),s <sub>2</sub> (l <sub>2</sub> ) |  |
| CR                       | Compare algebraic            | 19              | 2              | r <sub>1</sub> ,r <sub>2</sub>                                                                    | r <sub>1</sub> ,r <sub>2</sub>                                    |  |

<sup>\*</sup>Micro expansion feature

Table A-2. Instruction Repertoire (Part 2 of 16)

| Listing By Mnemonic Code |                          |                 |                |                                                                                                   |                                                                    |  |
|--------------------------|--------------------------|-----------------|----------------|---------------------------------------------------------------------------------------------------|--------------------------------------------------------------------|--|
|                          | Instruction Name         |                 | Byte<br>Length | Source Code Format                                                                                |                                                                    |  |
| Mnemonic                 |                          | Machine<br>Code |                | Explicit                                                                                          | Implicit                                                           |  |
| CVB                      | Convert to binary        | 4F              | 4              | r <sub>1</sub> ,d <sub>2</sub> (x <sub>2</sub> ,b <sub>2</sub> )                                  | r <sub>1</sub> ,s <sub>2</sub> (x <sub>2</sub> )                   |  |
| CVD                      | Convert to decimal       | 4E              | 4              | r <sub>1</sub> ,d <sub>2</sub> (x <sub>2</sub> ,b <sub>2</sub> )                                  | r <sub>1</sub> ,s <sub>2</sub> (x <sub>2</sub> )                   |  |
| D                        | Divide                   | 5D              | 4              | r <sub>1</sub> ,d <sub>2</sub> (x <sub>2</sub> ,b <sub>2</sub> )                                  | r <sub>1</sub> ,s <sub>2</sub> (x <sub>2</sub> )                   |  |
| DD*                      | Divide, long             | 6D              | 4              | r <sub>1</sub> ,d <sub>2</sub> (x <sub>2</sub> ,b <sub>2</sub> )                                  | r <sub>1</sub> ,s <sub>2</sub> (x <sub>2</sub> )                   |  |
| DDR*                     | Divide, long             | 2D              | 2              | r <sub>1</sub> ,r <sub>2</sub>                                                                    | r <sub>1</sub> ,r <sub>2</sub>                                     |  |
| DE*                      | Divide, short            | 7D              | 4              | r <sub>1</sub> ,d <sub>2</sub> (x <sub>2</sub> ,b <sub>2</sub> )                                  | r <sub>1</sub> ,s <sub>2</sub> (x <sub>2</sub> )                   |  |
| DER*                     | Divide, short            | 3D              | 2              | r <sub>1</sub> ,r <sub>2</sub>                                                                    | r <sub>1</sub> ,r <sub>2</sub>                                     |  |
| DIAG                     | Diagnose                 | 83              | 4              | (Privileged)                                                                                      | (Privileged)                                                       |  |
| DP                       | Divide decimal           | FD              | 6              | d <sub>1</sub> (l <sub>1</sub> ,b <sub>1</sub> ),d <sub>2</sub> (l <sub>2</sub> ,b <sub>2</sub> ) | s <sub>1</sub> (l <sub>1</sub> ),,s <sub>2</sub> (l <sub>2</sub> ) |  |
| DR*                      | Divide                   | 1D              | 2              | r <sub>1'</sub> r <sub>2</sub>                                                                    | r <sub>1</sub> ,r <sub>2</sub>                                     |  |
| ĒD                       | Edit                     | DE              | 6              | d <sub>1</sub> (I,b <sub>1</sub> ),d <sub>2</sub> (b <sub>2</sub> )                               | s <sub>1</sub> (1),s <sub>2</sub>                                  |  |
| EDMK*                    | Edit and mark            | DF              | 6              | d <sub>1</sub> (I,b <sub>1</sub> ),d <sub>2</sub> (b <sub>2</sub> )                               | s <sub>1</sub> (1),s <sub>2</sub>                                  |  |
| ≣X                       | Execute                  | 44              | 4              | r <sub>1</sub> ,d <sub>2</sub> (x <sub>2</sub> ,b <sub>2</sub> )                                  | r <sub>1</sub> ,s <sub>2</sub> (x <sub>2</sub> )                   |  |
| HDR*                     | Halve, long              | 24              | 2              | 1, 2, 2, 2, 2, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1,                                             | r <sub>1</sub> ,r <sub>2</sub>                                     |  |
| HER*                     | Halve, short             | 34              | 2              | r <sub>1</sub> ,r <sub>2</sub>                                                                    | r <sub>1</sub> ,r <sub>2</sub>                                     |  |
| HPR                      | Halt and proceed         | 99              | 4              | (Privileged)                                                                                      | (Privileged)                                                       |  |
| С                        | Insert Character         | 43              | 4              | r <sub>1</sub> ,d <sub>2</sub> (x <sub>2</sub> ,b <sub>2</sub> )                                  | r <sub>1</sub> ,s <sub>2</sub> (x <sub>2</sub> )                   |  |
| SK*                      | Insert storage key       | 09              | 2              | (Privileged)                                                                                      | (Privileged)                                                       |  |
| _                        | Load                     | 58              | 4              | r <sub>1</sub> ,d <sub>2</sub> (x <sub>2</sub> ,b <sub>2</sub> )                                  | r <sub>1</sub> ,s <sub>2</sub> (x <sub>2</sub> )                   |  |
| LA                       | Load address             | 41              | 4              | $r_1, d_2(x_2, b_2)$                                                                              | r <sub>1</sub> ,s <sub>2</sub> (x <sub>2</sub> )                   |  |
| _CDR*                    | Load complement, long    | 23              | 2              | 1, 2, 2, 2                                                                                        | 1, 2, 2                                                            |  |
| LCER*                    | Load complement, short   | 33              | 2              | r <sub>1</sub> ,r <sub>2</sub>                                                                    | 1, 2<br>r <sub>1,r</sub> 2                                         |  |
| .CR*                     | Load complement          | 13              | 2              | 1,12<br>r1,12                                                                                     | 1' 2<br>r <sub>1'</sub> r <sub>2</sub>                             |  |
| LCS                      | Load control storage     | В1              | 4              | (Privileged)                                                                                      | (Privileged)                                                       |  |
| LD*                      | Load, long               | 68              | 4              | r <sub>1</sub> ,d <sub>2</sub> (x <sub>2</sub> ,b <sub>2</sub> )                                  | r <sub>1</sub> ,s <sub>2</sub> (x <sub>2</sub> )                   |  |
| _DR*                     | Load, long               | 28              | 2              | r <sub>1</sub> ,r <sub>2</sub>                                                                    | r <sub>1</sub> , <sup>r</sup> 2                                    |  |
| _E*                      | Load, short              | 78              | 4              | r <sub>1</sub> ,d <sub>2</sub> (x <sub>2</sub> ,b <sub>2</sub> )                                  | r <sub>1</sub> ,s <sub>2</sub> (x <sub>2</sub> )                   |  |
| LER*                     | Load, short              | 38              | 2              | r <sub>1</sub> ,r <sub>2</sub>                                                                    | 1, <sup>r</sup> 2, <sup>2</sup> 2,                                 |  |
| _H                       | Load half word           | 48              | 4              | r <sub>1</sub> ,d <sub>2</sub> (x <sub>2</sub> ,b <sub>2</sub> )                                  | r <sub>1</sub> ,s <sub>2</sub> (x <sub>2</sub> )                   |  |
| _M                       | Load multiple            | 98              | 4              | r <sub>1</sub> ,r <sub>3</sub> ,d <sub>2</sub> (b <sub>2</sub> )                                  | '1' <sup>2</sup> '^2'<br>'1, <sup>r</sup> 3' <sup>\$</sup> 2       |  |
| _NDR*                    | Load negative, long      | 21              | 2              | r <sub>1</sub> ,r <sub>2</sub>                                                                    | r <sub>1</sub> ,r <sub>2</sub>                                     |  |
| NER*                     | Load negative, short     | 31              | 2              | 1'2<br>r <sub>1'</sub> r <sub>2</sub>                                                             | 11'2<br>r <sub>1</sub> ,r <sub>2</sub>                             |  |
| NR*                      | Load negative            | 11              | 2              | 11'2<br>r <sub>1'</sub> r <sub>2</sub>                                                            | 11'2<br>r <sub>1</sub> ,r <sub>2</sub>                             |  |
| _PDR*                    | Load positive, long      | 20              | 2              | 1'2<br>r <sub>1'</sub> r <sub>2</sub>                                                             | r <sub>1</sub> ,r <sub>2</sub>                                     |  |
| .PER*                    | Load positive, short     | 30              | 2              | 1''2<br>  '1' <sup>'</sup> 2                                                                      | 1''2<br>r <sub>1'</sub> r <sub>2</sub>                             |  |
| .PR*                     | Load positive            | 10              | 2              | '1'2<br>'1' <sup>2</sup>                                                                          | r <sub>1</sub> ,r <sub>2</sub>                                     |  |
| LPSW                     | Load program status word | 82              | 4              | (Privileged)                                                                                      | (Privileged)                                                       |  |
| _R                       | Load                     | 18              | 2              | r <sub>1</sub> ,r <sub>2</sub>                                                                    | r <sub>1</sub> ,r <sub>2</sub>                                     |  |
| TDR*                     | Load and test, long      | 22              | 2              | 1                                                                                                 |                                                                    |  |
| TER*                     | Load and test, short     | 32              | 2              | r <sub>1</sub> ,r <sub>2</sub>                                                                    | r <sub>1</sub> ,r <sub>2</sub><br>r <sub>1</sub> ,r <sub>2</sub>   |  |
| TR                       | Load and test            | 12              | 2              | r <sub>1</sub> ,r <sub>2</sub>                                                                    | '1''2<br>'1''2                                                     |  |
| Λ                        | Multiply                 | 5C              | 4              | r <sub>1</sub> ,d <sub>2</sub> (x <sub>2</sub> ,b <sub>2</sub> )                                  | r <sub>1</sub> ,s <sub>2</sub> (x <sub>2</sub> )                   |  |
| ND*                      | Multiply, long           | 6C              | 4              | r <sub>1</sub> ,d <sub>2</sub> (x <sub>2</sub> ,b <sub>2</sub> )                                  | r <sub>1</sub> ,s <sub>2</sub> (x <sub>2</sub> )                   |  |
| MDR*                     | Multiply, long           | 2C              | 2              | 1,1,2,2,2,2,7                                                                                     | 1′°2′^2′<br>r <sub>1′</sub> r <sub>2</sub>                         |  |

Table A-2. Instruction Repertoire (Part 3 of 16)

|          | Instruction Name             | Machine | Byte   | Source Code Format                                                                                |                                                                   |  |
|----------|------------------------------|---------|--------|---------------------------------------------------------------------------------------------------|-------------------------------------------------------------------|--|
| Mnemonic |                              | Code    | Length | Explicit                                                                                          | Implicit                                                          |  |
| ME*      | Multiply, short              | 7C      | 4      | r <sub>1</sub> ,d <sub>2</sub> (x <sub>2</sub> ,b <sub>2</sub> )                                  | r <sub>1</sub> ,s <sub>2</sub> (x <sub>2</sub> )                  |  |
| MER*     | Multiply, short              | 3C      | 2      | r <sub>1</sub> ,r <sub>2</sub>                                                                    | r <sub>1</sub> ,r <sub>2</sub>                                    |  |
| MH*      | Multiply half word           | 4C      | 4      | $r_1,d_2(x_2,b_2)$                                                                                | r <sub>1</sub> ,s <sub>2</sub> (x <sub>2</sub> )                  |  |
| MP       | Multiple decimal             | FC      | 6      | d <sub>1</sub> (l <sub>1</sub> ,b <sub>1</sub> ),d <sub>2</sub> (l <sub>2</sub> ,b <sub>2</sub> ) | s <sub>1</sub> (l <sub>1</sub> ),s <sub>2</sub> (l <sub>2</sub> ) |  |
| MR*      | Multiply                     | 1C      | 2      | r <sub>1</sub> ,r <sub>2</sub>                                                                    | r <sub>1</sub> ,r <sub>2</sub>                                    |  |
| мvc      | Move characters              | D2      | 6      | d <sub>1</sub> (I,b <sub>1</sub> ),d <sub>2</sub> (b <sub>2</sub> )                               | s <sub>1</sub> (1), s <sub>2</sub>                                |  |
| MVI      | Move immediate               | 92      | 4      | d <sub>1</sub> (b <sub>1</sub> ),i <sub>2</sub>                                                   | s <sub>1,i2</sub>                                                 |  |
| MVN      | Move numerics                | D1      | 6      | d <sub>1</sub> (I,b <sub>1</sub> ),d <sub>2</sub> (b <sub>2</sub> )                               | s <sub>1</sub> (I),s <sub>2</sub>                                 |  |
| MVO      | Move with offset             | F1      | 6      | d <sub>1</sub> (I <sub>1</sub> ,b <sub>1</sub> ),d <sub>2</sub> (I <sub>2</sub> ,b <sub>2</sub> ) | _                                                                 |  |
| MVZ      | Move zones                   | D3      | 6      | d <sub>1</sub> (1,b <sub>1</sub> ),d <sub>2</sub> (b <sub>2</sub> )                               | s <sub>1</sub> (1),s <sub>2</sub>                                 |  |
| N        | AND logical                  | 54      | 4      | r <sub>1</sub> ,d <sub>2</sub> (x <sub>2</sub> ,b <sub>2</sub> )                                  | r <sub>1</sub> ,s <sub>2</sub> (x <sub>2</sub> )                  |  |
| NC       | AND logical                  | D4      | 6      | d <sub>1</sub> (1,b <sub>1</sub> ),d <sub>2</sub> (b <sub>2</sub> )                               | s <sub>1</sub> (I),s <sub>2</sub>                                 |  |
| NI       | AND logical immediate        | 94      | 4      | d <sub>1</sub> (b <sub>1</sub> ),i <sub>2</sub>                                                   | s <sub>1</sub> ,i <sub>2</sub>                                    |  |
| NR       | AND logical                  | 14      | 2      | r <sub>1'</sub> r <sub>2</sub>                                                                    | r <sub>1</sub> ,r <sub>2</sub>                                    |  |
| 0        | OR logical                   | 56      | 4      | r <sub>1</sub> ,d <sub>2</sub> (x <sub>2</sub> ,b <sub>2</sub> )                                  | r <sub>1</sub> ,s <sub>2</sub> (x <sub>2</sub> )                  |  |
| ос       | OR logical                   | D6      | 6      | d <sub>1</sub> (I,b <sub>1</sub> ),d <sub>2</sub> (b <sub>2</sub> )                               | s <sub>1</sub> (I),s <sub>2</sub>                                 |  |
| OI       | OR logical immediate         | 96      | 4      | d <sub>1</sub> (b <sub>1</sub> ),i <sub>2</sub>                                                   | s <sub>1</sub> ,i <sub>2</sub>                                    |  |
| OR       | OR logical                   | 16      | 2      | r <sub>1</sub> ,r <sub>2</sub>                                                                    | r <sub>1</sub> ,r <sub>2</sub>                                    |  |
| PACK     | Pack                         | F2      | 6      | d <sub>1</sub> (l <sub>1</sub> ,b <sub>1</sub> ),d <sub>2</sub> (l <sub>2</sub> ,b <sub>2</sub> ) | s <sub>1</sub> (I <sub>1</sub> ),s <sub>2</sub> (I <sub>2</sub> ) |  |
| S        | Subtract                     | 5B      | 4      | r <sub>1</sub> ,d <sub>2</sub> (x <sub>2</sub> ,b <sub>2</sub> )                                  | r <sub>1</sub> ,s <sub>2</sub> (x <sub>2</sub> )                  |  |
| SD*      | Subtract normalized, long    | 6B      | 4      | r <sub>1</sub> ,d <sub>2</sub> (x <sub>2</sub> ,b <sub>2</sub> )                                  | r <sub>1</sub> ,s <sub>2</sub> (x <sub>2</sub> )                  |  |
| SDR*     | Subtract normalized, long    | 2B      | 2      | r <sub>1</sub> ,r <sub>2</sub>                                                                    | r <sub>1</sub> ,r <sub>2</sub>                                    |  |
| SE*      | Subtract normalized, short   | 7B      | 4      | $r_1,d_2(x_2,b_2)$                                                                                | r <sub>1</sub> ,s <sub>2</sub> (x <sub>2</sub> )                  |  |
| SER*     | Subtract normalized, short   | 3B      | 2      | r <sub>1</sub> ,r <sub>2</sub>                                                                    | r <sub>1</sub> ,r <sub>2</sub>                                    |  |
| SH       | Subtract half word           | 48      | 4      | $r_1,d_2(x_2,b_2)$                                                                                | r <sub>1</sub> ,s <sub>2</sub> (x <sub>2</sub> )                  |  |
| SIO      | Start I/O                    | 9C      | 4      | (Privileged)                                                                                      | (Privileged)                                                      |  |
| SL*      | Subtract logical             | 5F      | 4      | r <sub>1</sub> ,d <sub>2</sub> (x <sub>2</sub> ,b <sub>2</sub> )                                  | r <sub>1</sub> ,s <sub>2</sub> (x <sub>2</sub> )                  |  |
| SLA*     | Shift left single algebraic  | 8B      | 4      | r <sub>1</sub> ,d <sub>2</sub> (b <sub>2</sub> )                                                  | r <sub>1</sub> ,s <sub>2</sub>                                    |  |
| SLDA*    | Shift left double algebraic  | 8F      | 4      | r <sub>1</sub> ,d <sub>2</sub> (b <sub>2</sub> )                                                  | r <sub>1</sub> ,s <sub>2</sub>                                    |  |
| SLDL*    | Shift left double logical    | 8D      | 4      | r <sub>1</sub> ,d <sub>2</sub> (b <sub>2</sub> )                                                  | r <sub>1</sub> ,s <sub>2</sub>                                    |  |
| SLL      | Shift left single logical    | 89      | 4      | r <sub>1</sub> ,d <sub>2</sub> (b <sub>2</sub> )                                                  | r <sub>1</sub> ,s <sub>2</sub>                                    |  |
| SLM      | Supervisor load multiple     | В8      | 4      | (Privileged)                                                                                      | (Privileged)                                                      |  |
| SLR*     | Subtract logical             | 1F      | 2      | r <sub>1</sub> ,r <sub>2</sub>                                                                    | r <sub>1</sub> ,r <sub>2</sub>                                    |  |
| SP       | Subtract decimal             | FB      | 6      | d <sub>1</sub> (l <sub>1</sub> ,b <sub>1</sub> ),d <sub>2</sub> (l <sub>2</sub> ,b <sub>2</sub> ) | s <sub>1</sub> (l <sub>1</sub> ),s <sub>2</sub> (l <sub>2</sub> ) |  |
| SPM      | Set program mask             | 04      | 2      | r <sub>1</sub>                                                                                    | r <sub>1</sub>                                                    |  |
| SR       | Subtract                     | 1B      | 2      | ' <sub>1,</sub> r <sub>2</sub>                                                                    | r <sub>1</sub> ,r <sub>2</sub>                                    |  |
| SRA*     | Shift right single algebraic | 8A      | 4      | r <sub>1</sub> ,d <sub>2</sub> (b <sub>2</sub> )                                                  | r <sub>1</sub> ,s <sub>2</sub>                                    |  |
| SRDA*    | Shift right double algebraic | 8E      | 4      | r <sub>1</sub> ,d <sub>2</sub> (b <sub>2</sub> )                                                  | r <sub>1</sub> ,s <sub>2</sub>                                    |  |
| SRDL*    | Shift right double logical   | 8C      | 4      | r <sub>1</sub> ,d <sub>2</sub> (b <sub>2</sub> )                                                  | r <sub>1</sub> ,s <sub>2</sub>                                    |  |
| SRL      | Shift right single logical   | 88      | 4      | r <sub>1</sub> ,d <sub>2</sub> (b <sub>2</sub> )                                                  | r <sub>1</sub> ,s <sub>2</sub>                                    |  |

<sup>\*</sup>Micro expansion feature

Table A-2. Instruction Repertoire (Part 4 of 16)

|          | Instruction Name             | Machine<br>Code | Byte<br>Length | Source Code Format                                                                                |                                                                   |
|----------|------------------------------|-----------------|----------------|---------------------------------------------------------------------------------------------------|-------------------------------------------------------------------|
| Mnemonic |                              |                 |                | Explicit                                                                                          | Implicit                                                          |
| SSFS     | SOFTSCOPE forward scan       | A2              | 4              | (Privileged)                                                                                      | (Privileged)                                                      |
| SSK*     | Set system key               | 08              | 2              | (Privileged)                                                                                      | (Privileged)                                                      |
| SSM      | Set system mask              | 80              | 4              | (Privileged)                                                                                      | (Privileged)                                                      |
| SSRS     | SOFTSCOPE reverse scan       | A3              | 4              | (Privileged)                                                                                      | (Privileged)                                                      |
| SSTM     | Supervisor store multiple    | В0              | 4              | (Privileged)                                                                                      | (Privileged)                                                      |
| ST       | Store                        | 50              | 4              | r <sub>1</sub> ,d <sub>2</sub> (x <sub>2</sub> ,b <sub>2</sub> )                                  | r <sub>1</sub> ,s <sub>2</sub> (x <sub>2</sub> )                  |
| sтc      | Store character              | 42              | 4              | r <sub>1</sub> ,d <sub>2</sub> (x <sub>2</sub> ,b <sub>2</sub> )                                  | r <sub>1</sub> ,s <sub>2</sub> (x <sub>2</sub> )                  |
| STD*     | Store long                   | 60              | 4              | r <sub>1</sub> ,d <sub>2</sub> (x <sub>2</sub> ,b <sub>2</sub> )                                  | r <sub>1</sub> ,s <sub>2</sub> (x <sub>2</sub> )                  |
| STE*     | Store short                  | 70              | 4              | r <sub>1</sub> ,d <sub>2</sub> (x <sub>2</sub> ,b <sub>2</sub> )                                  | r <sub>1</sub> ,s <sub>2</sub> (x <sub>2</sub> )                  |
| sтн      | Store half word              | 40              | 4              | r <sub>1</sub> ,d <sub>2</sub> (x <sub>2</sub> ,b <sub>2</sub> )                                  | r <sub>1</sub> ,s <sub>2</sub> (x <sub>2</sub> )                  |
| STM      | Store multiple               | 90              | 4              | r <sub>1</sub> ,r <sub>3</sub> ,d <sub>2</sub> (b <sub>2</sub> )                                  | r <sub>1</sub> ,r <sub>3</sub> ,s <sub>2</sub>                    |
| STR      | Service timer register       | 03              | 2              | (Privileged)                                                                                      | (Privileged)                                                      |
| SU*      | Subtract unnormalized, short | 7F              | 4              | r <sub>1</sub> ,d <sub>2</sub> (x <sub>2</sub> ,b <sub>2</sub> )                                  | r <sub>1</sub> ,s <sub>2</sub> (x <sub>2</sub> )                  |
| SUR*     | Subtract unnormalized, short | 3F              | 2              | <sup>r</sup> 1' <sup>r</sup> 2                                                                    | r <sub>1′</sub> r <sub>2</sub>                                    |
| svc      | Supervisor call              | 0A              | 2              | i                                                                                                 | i                                                                 |
| SW*      | Subtract unnormalized, long  | 6F              | 4              | r <sub>1</sub> ,d <sub>2</sub> (x <sub>2</sub> ,b <sub>2</sub> )                                  | r <sub>1</sub> ,s <sub>2</sub> (x <sub>2</sub> )                  |
| SWR*     | Subtract unnormalized, long  | 2F              | 2              | <sup>r</sup> 1, <sup>r</sup> 2                                                                    | <sup>r</sup> 1' <sup>r</sup> 2                                    |
| тм       | Test under mask              | 91              | 4              | d <sub>1</sub> (b <sub>1</sub> ),i <sub>2</sub>                                                   | \$1, <sup>i</sup> 2                                               |
| TR       | Translate                    | DC              | 6              | d <sub>1</sub> (1,b <sub>1</sub> ),d <sub>2</sub> (b <sub>2</sub> )                               | s <sub>1</sub> (I),s <sub>2</sub>                                 |
| TRT      | Translate and test           | DD              | 6              | d <sub>1</sub> (I,b <sub>1</sub> ),d <sub>2</sub> (b <sub>2</sub> )                               | s <sub>1</sub> (I),s <sub>2</sub>                                 |
| TS*      | Test and set                 | 93              | 4              | d <sub>1</sub> (b <sub>1</sub> )                                                                  | s <sub>1</sub>                                                    |
| UNPK     | Unpack                       | F3              | 6              | d <sub>1</sub> (I <sub>1</sub> ,b <sub>1</sub> ),d <sub>2</sub> (I <sub>2</sub> ,b <sub>2</sub> ) | s <sub>1</sub> (1 <sub>1</sub> ),s <sub>2</sub> (1 <sub>2</sub> ) |
| ×        | Exclusive OR                 | 57              | 4              | r <sub>1</sub> ,d <sub>2</sub> (x <sub>2</sub> ,b <sub>2</sub> )                                  | r <sub>1</sub> ,s <sub>2</sub> (x <sub>2</sub> )                  |
| xc       | Exclusive OR                 | D7              | 6              | d <sub>1</sub> (I,b <sub>1</sub> ),d <sub>2</sub> (b <sub>2</sub> )                               | s <sub>1</sub> (I),s <sub>2</sub>                                 |
| xı       | Exclusive OR, immediate      | 97              | 4              | d <sub>1</sub> (b <sub>1</sub> ),i <sub>2</sub>                                                   | \$1, <sup>i</sup> 2                                               |
| XR       | Exclusive OR                 | 17              | 2              | <sup>r</sup> 1' <sup>r</sup> 2                                                                    | <sup>r</sup> 1, <sup>r</sup> 2                                    |
| ZAP      | Zero and add decimal         | F8              | 6              | d <sub>1</sub> (I <sub>1</sub> ,b <sub>1</sub> ),d <sub>2</sub> (I <sub>2</sub> ,b <sub>2</sub> ) | s <sub>1</sub> (1 <sub>1</sub> ),s <sub>2</sub> (1 <sub>2</sub> ) |

<sup>\*</sup>Micro expansion feature

Table A-2. Instruction Repertoire (Part 5 of 16)

| Listing By Alphabetic Instructions |                              |              |          |  |  |  |
|------------------------------------|------------------------------|--------------|----------|--|--|--|
| Instru                             | ction Name                   | Machine Code | Mnemonic |  |  |  |
| Add                                | (Native and 360/20 Modes)    | 1A           | (C)AR    |  |  |  |
| Add                                |                              | 5A           | A        |  |  |  |
| Add decimal                        |                              | FA           | (C)AP    |  |  |  |
| Add half word                      | (Native and 360/20 Modes)    | 4A           | (C)AH    |  |  |  |
| Add half word                      | (9200/9300 Mode only)        | (AA)         | (C)AH    |  |  |  |
| Add immediate                      |                              | 9A           | AI       |  |  |  |
| Add immediate                      | (9200/9300 Mode only)        | (A6)         | (C)AI    |  |  |  |
| Add logical                        | (9200/9300 Mode only)        | 1E           | (F)ALR   |  |  |  |
| Add logical                        |                              | 5E           | (F)AL    |  |  |  |
| Add normalized (long)              |                              | 2A           | (F)ADR   |  |  |  |
| Add normalized (long)              |                              | 6A           | (F)AD    |  |  |  |
| Add normalized (short)             |                              | 3A           | (F)AER   |  |  |  |
| Add normalized (short)             |                              | 7A           | (F)AE    |  |  |  |
| Add unnormalized (long)            |                              | 2E           | (F)AWR   |  |  |  |
| Add unnormalized (long)            |                              | 6E           | (F)AW    |  |  |  |
| Add unnormalized (short)           |                              | 3E           | (F)AUR   |  |  |  |
| Add unnormalized (short)           |                              | 7E           | (F)AU    |  |  |  |
| And                                |                              | 14           | NR       |  |  |  |
| And                                |                              | 54           | N        |  |  |  |
| And                                |                              | 94           | (C)NI    |  |  |  |
| And                                | (Native and 9200/9300 Modes) | D4           | (C)NC    |  |  |  |
| Branch and link                    |                              | 05           | BALR     |  |  |  |
| Branch and link                    | (Native and 9200/9300 Modes) | 45           | (C)BAL   |  |  |  |
| Branch and store                   | (360/20 Mode only)           | 4D           | (C)BAS   |  |  |  |
| Branch and store                   | (360/20 Mode only)           | 0D           | (C)BASR  |  |  |  |
| Branch on condition                | (Native and 360/20 Modes)    | 07           | (C)BCR   |  |  |  |
| Branch on condition                |                              | 47           | (C)BC    |  |  |  |
| Branch on count                    |                              | 06           | BCTR     |  |  |  |
| Branch on count                    |                              | 46           | вст      |  |  |  |

Table A-2. Instruction Repertoire (Part 6 of 16)

| Listing By Alphabetic Instructions |              |          |  |  |  |
|------------------------------------|--------------|----------|--|--|--|
| Instruction Name                   | Machine Code | Mnemonic |  |  |  |
| Branch on index high               | 86           | (F)BXH   |  |  |  |
| Branch on index low or equal       | 87           | (F)BXLE  |  |  |  |
| Compare                            | 19           | CR       |  |  |  |
| Compare                            | 59           | С        |  |  |  |
| Compare decimal                    | F9           | (C)CP    |  |  |  |
| Compare half word                  | 49           | (C)CH    |  |  |  |
| Compare logical                    | 15           | CLR      |  |  |  |
| Compare logical                    | 55           | CL       |  |  |  |
| Compare logical                    | 95           | (C)CLI   |  |  |  |
| Compare logical                    | D5           | (C)CLC   |  |  |  |
| Compare (long)                     | 29           | (F)CDR   |  |  |  |
| Compare (long)                     | 69           | (F)CD    |  |  |  |
| Compare (short)                    | 39           | (F)CER   |  |  |  |
| Compare (short)                    | 79           | (F)CE    |  |  |  |
| Convert to binary                  | 4F           | CVB      |  |  |  |
| Convert to decimal                 | 4E           | CVD      |  |  |  |
| Diagnose — privileged              | 83           | DIAG     |  |  |  |
| Divide                             | 1D           | (F)DR    |  |  |  |
| Divide                             | 5D           | D        |  |  |  |
| Divide decimal                     | FD           | (C)DP    |  |  |  |
| Divide (long)                      | 2D           | (F)DDR   |  |  |  |
| Divide (long)                      | 6D           | (F)DD    |  |  |  |
| Divide (short)                     | 3D           | (F)DER   |  |  |  |
| Divide (short)                     | 70           | (F)DE    |  |  |  |
| Edit                               | DE           | (C)ED    |  |  |  |
| Edit and mark                      | DF           | (F)EDMK  |  |  |  |
| Exclusive OR                       | 17           | XR       |  |  |  |
| Exclusive OR                       | 57           | x        |  |  |  |
| Exclusive OR                       | 97           | ΧI       |  |  |  |

Table A-2. Instruction Repertoire (Part 7 of 16)

| Listing By Alphabetic Instructions |              |          |  |  |
|------------------------------------|--------------|----------|--|--|
| Instruction Name                   | Machine Code | Mnemonic |  |  |
| Exclusive OR                       | D7           | хс       |  |  |
| Execute                            | 44           | EX       |  |  |
| Halt and proceed — privileged      | 99           | HPR      |  |  |
| Halve (long)                       | 24           | (F)HDR   |  |  |
| Halve (short)                      | 34           | (F)HER   |  |  |
| Insert character                   | 43           | IC       |  |  |
| Insert storage key — privileged    | 09           | (F)ISK   |  |  |
| Load                               | 18           | LR       |  |  |
| Load                               | 58           | L        |  |  |
| Load address                       | 41           | LA       |  |  |
| Load and test                      | 12           | LTR      |  |  |
| Load and test (long)               | 22           | (F)LTDR  |  |  |
| Load and test (short)              | 32           | (F)LTER  |  |  |
| Load complement                    | 13           | (F)LCR   |  |  |
| Load complement (long)             | 23           | (F)LCDR  |  |  |
| Load complement (short)            | 33           | (F)LCER  |  |  |
| Load control storage — privileged  | B1           | LCS      |  |  |
| Load half word                     | 48           | (C)LH    |  |  |
| Load (long)                        | 28           | (F)LDR   |  |  |
| Load (long)                        | 68           | (F)LD    |  |  |
| Load multiple                      | 98           | LM       |  |  |
| Load negative                      | 11           | (F)LNR   |  |  |
| Load negative (long)               | 21           | (F)LNDR  |  |  |
| Load negative (short)              | 31           | (F)LNER  |  |  |
| Load positive                      | 10           | (F)LPR   |  |  |
| Load positive (long)               | 20           | (F)LPDR  |  |  |
| Load positive (short)              | 30           | (F)LPER  |  |  |
| Load PSW — privileged              | 82           | LPSW     |  |  |
| Load (short)                       | 38           | (F)LER   |  |  |

Table A-2. Instruction Repertoire (Part 8 of 16)

| Instructi                           | on Name                           | Machine Code | Mnemoni |
|-------------------------------------|-----------------------------------|--------------|---------|
| Load (short)                        | 78                                | (F)LE        |         |
| Move                                |                                   | 92           | (C)MVI  |
| Move                                |                                   | D2           | (C)MVC  |
| Move numerics                       |                                   | D1           | (C)MVN  |
| Move with offset                    |                                   | F1           | (C)MVO  |
| Move zones                          | (Native and 9200/9300 Modes)      | D3           | (C)MVZ  |
| Multiply                            | (1.00.10 0.10 0.200,0000 1.10000, | 1C           | (F)MR   |
| Multiply                            |                                   | 5C           | M       |
| Multiply decimal                    |                                   | FC           | (C)MP   |
| Multiply half word                  |                                   | 4C           | (F)MH   |
| Multiply (long)                     |                                   | 2C           | (F)MDR  |
| Multiply (long)                     |                                   | 6C           | (F)MD   |
| Multiply (short)                    |                                   | 3C           | (F)MER  |
| Multiply (short)                    |                                   | 7C           | (F)ME   |
| OR                                  |                                   | 16           | OR      |
| OR .                                |                                   | 56           | 0       |
| OR .                                |                                   | 96           | (C)OI   |
| OR                                  | (Native and 9200/9300 Modes)      | D6           | (C)OC   |
| Pack                                | (Madive dira ezes), eses inicato, | F2           | (C)PAC  |
| Service timer register – privileged |                                   | 03           | STR     |
| Set program mask                    |                                   | 04           | SPM     |
| Set storage key — privileged        |                                   | 08           | (F)SSK  |
| Set system mask — privileged        |                                   | 80           | SSM     |
| Shift left double                   |                                   | 8F           | (F)SLDA |
| Shift left double logical           |                                   | 8D           | (F)SLDL |
| Shift left single                   |                                   | 8B           | (F)SLA  |
| Shift left single logical           |                                   | 89           | SLL.    |
| Shift right double                  |                                   | 8E           | (F)SRDA |
| Shift right double logical          |                                   | 8C           | (F)SRDI |
| Shift right single                  |                                   | 8A           | (F)SRA  |
| Shift right single logical          |                                   | 88           | SRL     |

| Listing By Alphabetic Instructions    |                                        |          |        |  |  |
|---------------------------------------|----------------------------------------|----------|--------|--|--|
| Instruc                               | Machine Code                           | Mnemonic |        |  |  |
| SOFTSCOPE forward scan — pri          | SOFTSCOPE forward scan — privileged    |          |        |  |  |
| SOFTSCOPE reverse scan — priv         | rileged                                | А3       | SSRS   |  |  |
| Start I/O privileged                  |                                        | 9C       | SIO    |  |  |
| Store                                 |                                        | 50       | ST     |  |  |
| Store character                       |                                        | 42       | STC    |  |  |
| Store half word                       |                                        | 40       | (C)STH |  |  |
| Store (long)                          |                                        | 60       | (F)STD |  |  |
| Store multiple                        |                                        | 90       | STM    |  |  |
| Store (short)                         |                                        | 70       | (F)STE |  |  |
| Subtract                              | (Native and 360/20 Modes)              | 1B       | (C)SR  |  |  |
| Subtract                              |                                        | 5B       | s      |  |  |
| Subtract decimal                      |                                        | FB       | (C)SP  |  |  |
| Subtract half word                    | (Native and 360/20 Modes)              | 4B       | (C)SH  |  |  |
| Subtract half word                    | (9200/9300 Mode only)                  | (AB)     | (C)SH  |  |  |
| Subtract logical                      |                                        | 1F       | (F)SLR |  |  |
| Subtract logical                      |                                        | 5F       | (F)SL  |  |  |
| Subtract normalized (long)            |                                        | 2B       | (F)SDR |  |  |
| Subtract normalized (long)            |                                        | 6B       | (F)SD  |  |  |
| Subtract normalized (short)           |                                        | 3В       | (F)SER |  |  |
| Subtract normalized (short)           |                                        | 7B       | (F)SE  |  |  |
| Subtract unnormalized (long)          |                                        | 2F       | (F)SWR |  |  |
| Subtract unnormalized (long)          |                                        | 6F       | (F)SW  |  |  |
| Subtract unnormalized (short)         | Subtract unnormalized (short)          |          |        |  |  |
| Subtract unnormalized (short)         | Subtract unnormalized (short)          |          |        |  |  |
| Supervisor call                       | 0A                                     | svc      |        |  |  |
| Supervisor load multiple — privileged |                                        | 88       | SLM    |  |  |
| Supervisor store multiple – priv      | Supervisor store multiple — privileged |          | SSTM   |  |  |
| Test and set                          |                                        | 93       | (F)TS  |  |  |
| Test under mask                       |                                        | 91       | (C)TM  |  |  |

Table A-2. Instruction Repertoire (Part 10 of 16)

| Listing By Alphabetic Instructions |                          |  |  |  |
|------------------------------------|--------------------------|--|--|--|
| Machine Code                       | Mnemonic                 |  |  |  |
| DC                                 | (C)TR                    |  |  |  |
| DD                                 | TRT                      |  |  |  |
| F3                                 | (C)UNPK                  |  |  |  |
| F8                                 | (C)ZAP                   |  |  |  |
|                                    | Machine Code  DC  DD  F3 |  |  |  |

#### NOTES:

- Tag symbol (F) before mnemonic indicates instructions that are added as features.
- Tag symbol (C) before mnemonic indicates instruction available in native mode and in 9200/9300 and 360/20 compatibility modes, unless indicated otherwise by notes. The absence of (C) indicates instruction available in native mode only. Opcodes in parentheses execute in 9200/9300 compatibility mode only.

Table A-2. Instruction Repertoire (Part 11 of 16)

|              | Listing By Machine Code                |                                     |                           |  |  |
|--------------|----------------------------------------|-------------------------------------|---------------------------|--|--|
| Machine Code | Machine Code Mnemonic Instruction Name |                                     |                           |  |  |
| 03           | STR                                    | Service timer register - privileged |                           |  |  |
| 04           | SPM                                    | Set program mask                    |                           |  |  |
| 05           | BALR                                   | Branch and link                     |                           |  |  |
| 06           | BCTR                                   | Branch on count                     |                           |  |  |
| 07           | (C)BCR                                 | Branch on condition                 | (Native and 360/20 Modes) |  |  |
| 08           | (F)SSK                                 | Set storage key — privileged        |                           |  |  |
| 09           | (F)ISK                                 | Insert storage key — privileged     |                           |  |  |
| 0A           | svc                                    | Supervisor call                     |                           |  |  |
| 0D           | (C)BASR                                | Branch and store                    | (360/20 Mode only)        |  |  |
| 10           | (F)LPR                                 | Load positive                       |                           |  |  |
| 11           | (F)LNR                                 | Load negative                       | ,                         |  |  |
| 12           | LTR                                    | Load and test                       |                           |  |  |
| 13           | (F)LCR                                 | Load complement                     |                           |  |  |
| 14           | NR                                     | AND                                 |                           |  |  |
| 15           | CLR                                    | Compare logical                     |                           |  |  |
| 16           | OR                                     | OR                                  |                           |  |  |
| 17           | XR                                     | Exclusive OR                        |                           |  |  |
| 18           | LR                                     | Load                                |                           |  |  |
| 19           | CR                                     | Compare                             |                           |  |  |
| 1A           | (C)AR                                  | Add                                 | (Native and 360/20 Modes) |  |  |
| 1B           | (C)SR                                  | Subtract                            | (Native and 360/20 Modes) |  |  |
| 1C           | (F)MR                                  | Multiply                            |                           |  |  |
| 1D           | (F)DR                                  | Divide                              |                           |  |  |
| 1E           | (F)ALR                                 | Add logical                         |                           |  |  |
| 1F           | (F)SLR                                 | Subtract logical                    |                           |  |  |
| 20           | (F)LPDR                                | Load positive (long)                |                           |  |  |
| 21           | (F)LNDR                                | Load negative (long)                |                           |  |  |
| 22           | (F)LTDR                                | Load and test (long)                |                           |  |  |
| 23           | (F)LCDR                                | Load complement (long)              |                           |  |  |

Table A-2. Instruction Repertoire (Part 12 of 16)

| Listing By Machine Code |                                        |                               |                              |  |  |
|-------------------------|----------------------------------------|-------------------------------|------------------------------|--|--|
| Machine Code            | Machine Code Mnemonic Instruction Name |                               |                              |  |  |
| 24                      | (F)HDR                                 | Haive (long)                  |                              |  |  |
| 28                      | (F)LDR                                 | Load (long)                   |                              |  |  |
| 29                      | (F)CDR                                 | Compare (long)                |                              |  |  |
| 2A                      | (F)ADR                                 | Add normalized (long)         |                              |  |  |
| 2B                      | (F)SDR                                 | Subtract normalized (long)    |                              |  |  |
| 2C                      | (F)MDR                                 | Multiply (long)               |                              |  |  |
| 2D                      | (F)DDR                                 | Divide (long)                 |                              |  |  |
| 2E                      | (F)AWR                                 | Add unnormalized (long)       |                              |  |  |
| 2F                      | (F)SWR                                 | Subtract unnormalized (long)  |                              |  |  |
| 30                      | (F)LPER                                | Load positive (short)         |                              |  |  |
| 31                      | (F)LNER                                | Load negative (short)         |                              |  |  |
| 32                      | (F)LTER                                | Load and test (short)         | •                            |  |  |
| 33                      | (F)LCER                                | Load complement (short)       |                              |  |  |
| 34                      | (F)HER                                 | Halve (short)                 |                              |  |  |
| 38                      | (F)LER                                 | Load (short)                  |                              |  |  |
| 39                      | (F)CER                                 | Compare (short)               |                              |  |  |
| 3A                      | (F)AER                                 | Add normalized (short)        |                              |  |  |
| 3 <b>B</b>              | (F)SER                                 | Subtract normalized (short)   |                              |  |  |
| 3C                      | (F)MER                                 | Multiply (short)              |                              |  |  |
| 3D                      | (F)DER                                 | Divide (short)                |                              |  |  |
| 3E                      | (F)AUR                                 | Add unnormalized (short)      |                              |  |  |
| 3F                      | (F)SUR                                 | Subtract unnormalized (short) |                              |  |  |
| 40                      | (C)STH                                 | Store half word               |                              |  |  |
| 41                      | LA                                     | Load address                  |                              |  |  |
| 42                      | STC                                    | Store character               |                              |  |  |
| 43                      | ıc                                     | Insert character              |                              |  |  |
| 44                      | EX                                     | Execute                       |                              |  |  |
| 45                      | (C)BAL                                 | Branch and link               | (Native and 9200/9300 Modes) |  |  |
| 46                      | вст                                    | Branch on count               |                              |  |  |

Table A-2. Instruction Repertoire (Part 13 of 16)

|              | Listing By Machine Code                |                            |                           |  |
|--------------|----------------------------------------|----------------------------|---------------------------|--|
| Machine Code | lachine Code Mnemonic Instruction Name |                            |                           |  |
| 47           | (C)BC                                  | Branch on condition        |                           |  |
| 48           | (C)LH                                  | Load half-word             |                           |  |
| 49           | (с)сн                                  | Compare half-word          |                           |  |
| 4A           | (C)AH                                  | Add half-word              | (Native and 360/20 Modes) |  |
| 4B           | (C)SH                                  | Subtract half-word         | (Native and 360/20 Modes) |  |
| 4C           | (Ғ)МН                                  | Multiply half-word         |                           |  |
| 4D           | (C)BAS                                 | Branch and store           | (360/20 Mode only)        |  |
| 4E           | CVD                                    | Convert to decimal         |                           |  |
| 4F           | CVB                                    | Convert to binary          |                           |  |
| 50           | ST                                     | Store                      |                           |  |
| 54           | N                                      | AND                        |                           |  |
| 55           | CL                                     | Compare logical            | •                         |  |
| 56           | О                                      | OR                         |                           |  |
| 57           | x                                      | Exclusive OR               |                           |  |
| 58           | L                                      | Load                       |                           |  |
| 59           | С                                      | Compare                    |                           |  |
| 5A           | A                                      | Add                        |                           |  |
| 5B           | s                                      | Subtract                   |                           |  |
| 5C           | м                                      | Multiply                   |                           |  |
| 5D           | D .                                    | Divide                     |                           |  |
| 5E           | (F)AL                                  | Add logical                |                           |  |
| 5F           | (F)SL                                  | Subtract logical           |                           |  |
| 60           | (F)STD                                 | Store (long)               |                           |  |
| 68           | (F)LD                                  | Load (long)                |                           |  |
| 69           | (F)CD                                  | Compare (long)             |                           |  |
| 6A           | (F)AD                                  | Add normalized (long)      |                           |  |
| 6B           | (F)SD                                  | Subtract normalized (long) |                           |  |
| 6C           | (F)MD                                  | Multiply (long)            |                           |  |
| 6D           | (F)DD                                  | Divide (long)              |                           |  |

Table A-2. Instruction Repertoire (Part 14 of 16)

|              | Listing By Machine Code |                               |  |  |
|--------------|-------------------------|-------------------------------|--|--|
| Machine Code | Mnemonic                | Instruction Name              |  |  |
| 6E           | (F)AW                   | Add unnormalized (long)       |  |  |
| 6F           | (F)SW                   | Subtract unnormalized (long)  |  |  |
| 70           | (F)STE                  | Store (short)                 |  |  |
| 78           | (F)LE                   | Load (short)                  |  |  |
| 79           | (F)CE                   | Compare (short)               |  |  |
| 7A           | (F)AE                   | Add normalized (short)        |  |  |
| 7B           | (F)SE                   | Subtract normalized (short)   |  |  |
| 7C           | (F)ME                   | Multiply (short)              |  |  |
| 7D           | (F)DE                   | Divide (short)                |  |  |
| 7E           | (F)AU                   | Add unnormalized (short)      |  |  |
| 7F           | (F)SU                   | Subtract unnormalized (short) |  |  |
| 80           | SSM                     | Set system mask — privileged  |  |  |
| 82           | LPSW                    | Load PSW — privileged         |  |  |
| 83           | DIAG                    | Diagnose — privileged         |  |  |
| 86           | (F)BXH                  | Branch on index high          |  |  |
| 87           | (F)BXLE                 | Branch on index low or equal  |  |  |
| 88           | SRL                     | Shift right single logical    |  |  |
| 89           | SLL                     | Shift left single logical     |  |  |
| 8A           | (F)SRA                  | Shift right single            |  |  |
| 8B           | (F)SLA                  | Shift left single             |  |  |
| 8C           | (F)SRDL                 | Shift right double logical    |  |  |
| 8D           | (F)SLDL                 | Shift left double logical     |  |  |
| 8E           | (F)SRDA                 | Shift right double            |  |  |
| 8F           | (F)SLDA                 | Shift left double             |  |  |
| 90           | STM                     | Store multiple                |  |  |
| 91           | (C)TM                   | Test under mask               |  |  |
| 92           | (C)MVI                  | Move immediate                |  |  |
| 93           | (F)TS                   | Test and set                  |  |  |
| 94           | (C)NI                   | AND                           |  |  |

Table A-2. Instruction Repertoire (Part 15 of 16)

| Listing By Machine Code                |         |                                        |                              |  |
|----------------------------------------|---------|----------------------------------------|------------------------------|--|
| Machine Code Mnemonic Instruction Name |         |                                        |                              |  |
| 95                                     | (C)CLI  | Compare logical                        |                              |  |
| 96                                     | (C)OI   | OR                                     |                              |  |
| 97                                     | ΧI      | Exclusive OR                           |                              |  |
| 98                                     | LM      | Load multiple                          |                              |  |
| 99                                     | HPR     | Halt and proceed — privileged          |                              |  |
| 9A                                     | AI      | Add immediate                          |                              |  |
| 9C                                     | SIO     | Start I/O — privileged                 |                              |  |
| A2                                     | SSFS    | SOFTSCOPE forward scan — privileged    | i .                          |  |
| А3                                     | SSRS    | SOFTSCOPE reverse scan — privileged    |                              |  |
| (A6)                                   | (C)AI   | Add immediate                          | (9200/9300 Mode only)        |  |
| (AA)                                   | (C)AH   | Add half word                          | (9200/9300 Mode only)        |  |
| (AB)                                   | (C)SH   | Subtract half word                     | (9200/9300 Mode only)        |  |
| В0                                     | SSTM    | Supervisor store multiple – privileged |                              |  |
| B1                                     | LCS     | Load control storage — privileged      |                              |  |
| B8                                     | SLM     | Supervisor load multiple — privileged  |                              |  |
| D1                                     | (C)MVN  | Move numerics                          |                              |  |
| D2                                     | (C)MVC  | Move                                   |                              |  |
| D3                                     | (C)MVZ  | Move zones                             | (Native and 360/20 Modes)    |  |
| D4                                     | (C)NC   | AND                                    | (Native and 9200/9300 Modes) |  |
| D5                                     | (C)CLC  | Compare logical                        |                              |  |
| D6                                     | (C)OC   | OR                                     | (Native and 9200/9300 Modes) |  |
| D7                                     | хс      | Exclusive OR                           |                              |  |
| DC                                     | (C)TR   | Translate                              |                              |  |
| DD                                     | TRT     | Translate and test                     |                              |  |
| DE                                     | (C)ED   | Edit                                   |                              |  |
| DF                                     | (F)EDMK | Edit and mark                          |                              |  |
| F1                                     | (с)м∨о  | Move with off set                      |                              |  |
| F2                                     | (C)PACK | Pack                                   |                              |  |
| F3                                     | (C)UNPK | Unpack                                 |                              |  |

Table A-2. Instruction Repertoire (Part 16 of 16)

|              | Listing By Machine Code |                  |  |  |
|--------------|-------------------------|------------------|--|--|
| Machine Code | Mnemonic                | Instruction Name |  |  |
| F8           | (C)ZAP                  | Zero and add     |  |  |
| F9           | (C)CP                   | Compare decimal  |  |  |
| FA           | (C)AP                   | Add decimal      |  |  |
| FB           | (C)SP                   | Subtract decimal |  |  |
| FC           | (C)MP                   | Multiply decimal |  |  |
| FD           | (C)DP                   | Divide decimal   |  |  |

#### NOTES:

- 1. Tag symbol (F) before mnemonic indicates instructions that are added as features.
- Tag symbol (C) before mnemonic indicates instruction available in native mode and in 9200/9300
  and 360/20 compatibility modes, unless indicated otherwise by notes. The absence of (C) indicates
  instruction available in native mode only.
- 3. Opcodes in parentheses execute in 9200/9300 compatibility mode only.

Table A-3. Extended Mnemonic Branch Codes

| RR-Type          | Instructions                                    | RX-Type          | Instructions                         | ВС              | Equivalent                                          |                         |
|------------------|-------------------------------------------------|------------------|--------------------------------------|-----------------|-----------------------------------------------------|-------------------------|
| Mnemonic<br>Code | Hexadecimal<br>Operation<br>Code m <sub>1</sub> | Mnemonic<br>Code | Hexadecimal<br>Operation<br>Code m 1 |                 | Explicit<br>Form                                    | Function                |
| BR               | 07 F                                            | _                | _                                    | BCR             | 15,r <sub>2</sub>                                   | Branch unconditionally  |
| NOPR             | 07 0                                            | _                | -                                    | BCR             | 0,r <sub>2</sub>                                    | No operation            |
| -                | -                                               | В                | 47 F                                 | ВС              | 15,d <sub>2</sub> (x <sub>2</sub> ,b <sub>2</sub> ) | Branch unconditionally  |
| _                | -                                               | NOP              | 47 0                                 | BC              | 0,d <sub>2</sub> (x <sub>2</sub> ,b <sub>2</sub> )  | No operation            |
|                  |                                                 | Use              | ed After Compari                     | son Instruction | ons                                                 |                         |
| BHR              | 07 2                                            | вн               | 47 2                                 | ВС              | 2,d <sub>2</sub> (x <sub>2</sub> ,b <sub>2</sub> )  | Branch if high          |
| BLR              | 07 4                                            | BL               | 47.4                                 | ВС              | 4,d <sub>2</sub> (x <sub>2</sub> ,b <sub>2</sub> )  | Branch if low           |
| BER              | 07 8                                            | BE               | 47 8                                 | ВС              | 8,d <sub>2</sub> (x <sub>2</sub> ,b <sub>2</sub> )  | Branch if equal         |
| BNHR             | 0 <b>7</b> D                                    | BNH              | 47 D                                 | вс              | 13,d <sub>2</sub> (x <sub>2</sub> ,b <sub>2</sub> ) | Branch if not high      |
| BNLR             | 07 B                                            | BNL              | 47 B                                 | вс              | 11,d <sub>2</sub> (x <sub>2</sub> ,b <sub>2</sub> ) | Branch if not low       |
| BNER             | 07 7                                            | BNE              | 47 7                                 | ВС              | 7,d <sub>2</sub> (x <sub>2</sub> ,b <sub>2</sub> )  | Branch if not equal     |
|                  |                                                 | Used             | After Test-Under-                    | Mask Instruc    | tions                                               |                         |
| BOR              | 07 1                                            | во               | 47 1                                 | ВС              | 1,d <sub>2</sub> (x <sub>2</sub> ,b <sub>2</sub> )  | Branch if all ones      |
| BZR              | 07 8                                            | ВZ               | 478                                  | ВС              | 8,d <sub>2</sub> (x <sub>2</sub> ,b <sub>2</sub> )  | Branch if all zeros     |
| BMR              | 07 4                                            | вм               | 47 4                                 | вс              | 4,d <sub>2</sub> (x <sub>2</sub> ,b <sub>2</sub> )  | Branch if mixed         |
| BNOR             | 07 E                                            | BNO              | 47 E                                 | вс              | 14,d <sub>2</sub> (x <sub>2</sub> ,b <sub>2</sub> ) | Branch if not all ones  |
| BNZR             | 07 7                                            | BNZ              | 47 7                                 | ВС              | 7,d <sub>2</sub> (x <sub>2</sub> ,b <sub>2</sub> )  | Branch if not all zeros |
| BNMR             | 07 B                                            | BNM              | 47 B                                 | BC              | 11,d <sub>2</sub> (x <sub>2</sub> ,b <sub>2</sub> ) | Branch if not mixed     |
|                  |                                                 | Use              | ed After Arithme                     | tic Instructio  | ns                                                  |                         |
| BOR              | 07 1                                            | во               | 47 1                                 | вс              | 1,d <sub>2</sub> (x <sub>2</sub> ,b <sub>2</sub> )  | Branch if overflow      |
| BZR              | 07 8                                            | вz               | 47 8                                 | ВС              | 8,d <sub>2</sub> (x <sub>2</sub> ,b <sub>2</sub> )  | Branch if zero          |
| BMR              | 07 4                                            | вм               | 474                                  | ВС              | 4,d <sub>2</sub> (x <sub>2</sub> ,b <sub>2</sub> )  | Branch if minus         |
| BPR              | 07 2                                            | ВР               | 47 2                                 | ВС              | 2,d <sub>2</sub> (x <sub>2</sub> ,b <sub>2</sub> )  | Branch if positive      |
| BNOR             | 07 E                                            | BNO              | 47 E                                 | вс              | 14,d <sub>2</sub> (x <sub>2</sub> ,b <sub>2</sub> ) | Branch if not overflow  |
| BNZR             | 07 7                                            | BNZ              | 477                                  | ВС              | 7,d <sub>2</sub> (x <sub>2</sub> ,b <sub>2</sub> )  | Branch if not zero      |
| BNMR             | 07 B                                            | вим              | 47 B                                 | ВС              | 11,d <sub>2</sub> (x <sub>2</sub> ,b <sub>2</sub> ) | Branch if not minus     |
| BNPR             | 07 D                                            | BNP              | 47 D                                 | ВС              | 13,d <sub>2</sub> (x <sub>2</sub> ,b <sub>2</sub> ) | Branch if not positive  |

| Classification       | Operator | Description                                         | Hierarchy |
|----------------------|----------|-----------------------------------------------------|-----------|
| Arithmetic operators | */       | A*/B is equivalent to A*2 <sup>B</sup>              | 6         |
|                      | //       | Covered quotient, A//B is equivalent to (A+B-1)/B   | 5         |
|                      | /        | A/B means arithmetic quotient of A and B.           | 5         |
|                      | *        | A*B means arithmetic product of A and B.            | 5         |
|                      | -        | A—B means arithmetic difference of A and B.         | 4         |
|                      | +        | A+B means arithmetic sum of A and B.                | 4         |
| Logical operators    | **       | A**B means logical product                          | 3         |
| !                    | ++       | A++B means logical sum 🔃<br>of A and B.             | 2         |
|                      |          | A—B means logical difference                        | 2         |
| Relational operators | =        | A=B has value 1 if true;<br>has value 0 if false.   | 1         |
|                      | >        | A > B has value 1 if true;<br>has value 0 if false. | 1         |
|                      | <        | A < B has value 1 if true;<br>has value 0 if false. | 1         |

Table A-5. Comparison of Terms

|        | Term                                  |        | Examples          |
|--------|---------------------------------------|--------|-------------------|
| SDTs   | · · · · · · · · · · · · · · · · · · · | CLI    | AREA10, 10        |
|        | Can be used in the 1st or 2nd         |        | SDT               |
|        | operands.                             | MVI    | AREAB, X'C2'      |
|        | May be used in application            |        | SĎT               |
|        | instructions and in assembler         | MVC    | 33 (10R5),3(R8)   |
|        | directions.                           |        | SOT SOT SOT       |
| Litera | ls                                    | MVC    | AREA10,=C'10'     |
| •      | May only be used in the last          |        | Literal           |
|        | operand.                              | MVC    | AREA10,=X'F1F0'   |
| •      | May not be used in assembler          |        | Literal           |
|        | directives.                           | CLC    | ONSW,=B'11111111' |
| -      | Literals are preceded by an           |        | Literal           |
|        | equal (=) sign.                       |        |                   |
| Symbo  | ols for constants                     | AREA10 | DS CL2            |
|        | May be used in the 1st or 2nd         | NO10   | DC C'10'          |
|        | operands.                             | MOVE10 | MVC AREA10,NO10   |
| •      | May be used in application            |        | symbols           |
|        | instructions and in assembler         |        | 371110013         |
|        | directives.                           |        |                   |

Table A-6. Characteristics of Constant and Storage Definition Type Codes

| _            | 0                              |             | Source Code            |      | Storage                                 | Truncation |          | Length in E         | ytes                    |
|--------------|--------------------------------|-------------|------------------------|------|-----------------------------------------|------------|----------|---------------------|-------------------------|
| Type<br>Code | Constant or<br>Storage Type    | Alignment   | Specification          |      | Format                                  | or Padding | Implied  | Minimum<br>Explicit | Maximum<br>Explicit *   |
| С            | Character                      | None        | Characters             | C. , | Character                               | Right      | Variable | 1                   | 256 (DC)<br>65,535 (DS) |
| x            | Hexadecimal                    | None        | Hexadecimal digits     | x' ' | Hexadecimal                             | Left       | Variable | 1                   | 256 (DC)<br>65,535 (DS) |
| В            | Binary                         | None        | Binary<br>digits       | В' ′ | Binary                                  | Left       | Variable | 1                   | 256                     |
| P            | Packed decima                  | None        | Decimal<br>digits      | Р' ′ | Packed<br>decimal                       | Left       | Variable | 1                   | 16                      |
| z            | Zoned decimal                  | None        | Decimal<br>digits      | Z' ′ | Character                               | Left       | Variable | 1                   | 16                      |
| н            | Half word,<br>fixed point      | Half word   | Decimal<br>digits      | н. , | Fixed-point<br>binary                   | Left       | 2        | 1                   | 8                       |
| F            | Full word,<br>fixed point      | Full word   | Decimal<br>digits      | F' ' | Fixed-point<br>binary                   | Left       | 4        | 1                   | 8                       |
| Y            | Half-word<br>address           | Half word   | Expression             | Y( ) | Binary                                  | Left       | 2        | 1                   | 2                       |
| A            | Full-word<br>address           | Full word   | Expression             | A( ) | Binary                                  | Left       | 4        | 1                   | 4                       |
| s            | Base and displacement          | Half word   | One or two expressions | S( ) | Base and displacement                   | None       | 2        | 2                   | 2                       |
| V            | External address               | Full word   | Relocatable<br>symbol  | V( ) | Binary                                  | Left       | 4        | 3                   | 4                       |
| E            | Full word,<br>floating point   | Full word   | Decimal<br>digits      | E, , | Floating-<br>point binary<br>normalized | Right      | 4        | 1                   | 8                       |
| D            | Double word,<br>floating point | Double word | Decimal<br>digits      | D' ' | Floating-<br>point binary<br>normalized | Right      | 8        | 1                   | 8                       |

<sup>\*</sup>The maximum explicit length in bytes is that total length produced by the explicit length factor times the duplication factor.

# Table A-7. PROC, MACRO, and Call Instruction Comparison

#### PROC CONSTRUCTION

|         | LABEL                  | $\Delta$ OPERATION $\Delta$    |                      | OPERAND                                     |
|---------|------------------------|--------------------------------|----------------------|---------------------------------------------|
| HEADING | [&symbol]<br>call-name | PROC<br>NAME                   | [&pos,n]<br>[pos-0]  | [,&key <sub>1</sub> =,,&key <sub>m</sub> =] |
| BODY    | symbol &symbol &symbol | mnemonic-code<br>mnemonic-code | operands<br>operands |                                             |
| TRAILER | unused                 | END                            | unused               |                                             |

## MACRO CONSTRUCTION

|           | LABEL                             | ΔορεπατίονΔ                 | OPERAND                                                                             |
|-----------|-----------------------------------|-----------------------------|-------------------------------------------------------------------------------------|
| 115451110 | unused                            | MACRO                       | unused                                                                              |
| HEADING   | [&symbol]                         | call-name                   | [&pos <sub>1</sub> ,,&pos <sub>n</sub> ][,&key <sub>1</sub> =,,&key <sub>m</sub> =] |
| BODY      | symbol & symbol & symbol & symbol | mnemonic-code mnemonic-code | operands<br>operands                                                                |
| TRAILER   | unused                            | MEND                        | unused                                                                              |

## CALL INSTRUCTION FORMAT

| LABEL    | $\Delta$ OPERATION $\Delta$ | OPERAND                                              |
|----------|-----------------------------|------------------------------------------------------|
| [symbol] | call-name                   | [p <sub>1</sub> ,p <sub>2</sub> ,,p <sub>252</sub> ] |

#### Addressing

A storage location outside the range of the installed storage is referenced by a program-specified address.

#### ■ Data

- An invalid sign or digit code is detected in decimal operands.
- Fields in decimal arithmetic overlap incorrectly.
- The first operand of the multiply decimal instruction does not have a sufficient number of high-order zero digits.

#### Decimal Divide

The quotient of a divide decimal instruction exceeds the capacity of the quotient part of the first operand field.

#### Decimal Overflow

The result of an add decimal, subtract decimal, or zero and add instruction exceeds the capacity of the first operand location.

#### Execute

The subject instruction of an execute instruction is an execute instruction.

## ■ Exponent Overflow

The final characteristic resulting from a floating-point arithmetic operand exceeds 127.

#### Exponent Underflow

The final characteristic resulting from a floating-point arithmetic operation is less than zero.

Table A-8. Check-off Table Terms

| General                                                                                                           |      |                |                                     | Possible Program Exceptions                                             |                                                                                                           |  |  |  |
|-------------------------------------------------------------------------------------------------------------------|------|----------------|-------------------------------------|-------------------------------------------------------------------------|-----------------------------------------------------------------------------------------------------------|--|--|--|
| OPCODE                                                                                                            |      | FORMAT<br>TYPE | OBJECT<br>INST.<br>LGTH.<br>(BYTES) | ☐ ADDRESSING ☐ DATA (INVALID SIGN/DIGIT) ☐ DECIMAL DIVIDE               | ☐ PROTECTION ☐ SIGNIFICANCE ☐ SPECIFICATION:                                                              |  |  |  |
|                                                                                                                   |      |                |                                     | ☐ DECIMAL OVERFLOW ☐ EXECUTE ☐ EXPONENT OVERFLOW                        | □ NOT A FLOATING-POINT REGISTER     □ OP 1 NOT ON HALF-WORD BOUNDARY     □ OP 2 NOT ON HALF-WORD BOUNDARY |  |  |  |
|                                                                                                                   | Cond | dition Code    | s                                   | ☐ EXPONENT UNDERFLOW ☐ FIXED-POINT DIVIDE                               | OP 2 NOT ON FULL-WORD BOUNDARY OP 2 NOT ON DOUBLE-WORD                                                    |  |  |  |
| ☐ IF RESULT = 0, SET TO 0 ☐ IF RESULT < 0, SET TO 1 ☐ IF RESULT > 0, SET TO 2 ☐ IF OVERFLOW, SET TO 3 ☐ UNCHANGED |      |                | ) 1<br>) 2                          | FIXED-POINT DIVIDE FIXED-POINT OVERFLOW FLOATING-POINT DIVIDE OPERATION | BOUNDARY  OP 1 NOT EVEN NUMBERED REGISTER  OP 1 NOT ODD NUMBERED REGISTER  NONE                           |  |  |  |

## Explanation:

#### Fixed-Point Divide

The quotient of a fixed-point divide operation exceeds the capacity of the first operand (including division by zero), or the result of a *convert to binary* instruction exceeds 31 bits.

#### Fixed-Point Overflow

A fixed-point add or subtract operation exceeds the capacity of the first operand field.

#### Floating-Point Divide

The divisor fraction in a floating-point divide operation is equal to zero.

#### Operation

An illegal operation has been attempted or an operation using a noninstalled processor feature has been attempted.

#### Protection

A storage protection violation occurs on a program-generated address, when the protection feature is installed.

## Significance

The final fraction resulting from a floating-point addition or subtraction is equal to zero.

## Specification

- The unit of information referenced is not on an appropriate boundary.
- An invalid modifier field is specified in the STR instruction.
- The R<sub>1</sub> field of an instruction which uses an even/odd pair of registers (64-bit operand) does not specify an even register.
- A floating-point register other than 0, 2, 4, or 6 is specified.
- A multiplicand or divisor in decimal arithmetic exceeds 15 digits and sign.
- The first operand field is shorter than, or equal in length to, the second operand in decimal multiply and decimal divide instructions.

**Appendix B. Character Set Code References** 



|             | Printed | Card    | ASCII       |         | EBCD        | ıc      |  |  |  |
|-------------|---------|---------|-------------|---------|-------------|---------|--|--|--|
| Character   | Symbol  | Punches | Hexadecimal | Decimal | Hexadecimal | Decimal |  |  |  |
|             | Letters |         |             |         |             |         |  |  |  |
| Uppercase A | А       | 12–1    | 41          | 65      | C1          | 193     |  |  |  |
| Uppercase B | В       | 12–2    | 42          | 66      | C2          | 194     |  |  |  |
| Uppercase C | С       | 12–3    | 43          | 67      | С3          | 195     |  |  |  |
| Uppercase D | D       | 12–4    | 44          | 68      | C4          | 196     |  |  |  |
| Uppercase E | E       | 12–5    | 45          | 69      | C5          | 197     |  |  |  |
| Uppercase F | F       | 12–6    | 46          | 70      | C6          | 198     |  |  |  |
| Uppercase G | G       | 12–7    | 47          | 71      | C7          | 199     |  |  |  |
| Uppercase H | Н       | 12-8    | 48          | 72      | C8          | 200     |  |  |  |
| Uppercase I | 1       | 12–9    | 49          | 73      | C9          | 201     |  |  |  |
| Uppercase J | J       | 11-1    | 4A          | 74      | D1          | 209     |  |  |  |
| Uppercase K | к       | 11–2    | 4B          | 75      | D2          | 210     |  |  |  |
| Uppercase L | L       | 11–3    | 4C          | 76      | D3          | 211     |  |  |  |
| Uppercase M | м       | 11-4    | 4D          | 77      | D4          | 212     |  |  |  |
| Uppercase N | N       | 11-5    | 4E          | 78      | D5          | 213     |  |  |  |
| Uppercase O | 0       | 11–6    | 4F          | 79      | D6          | 214     |  |  |  |
| Uppercase P | Р       | 11-7    | 50          | 80      | D7          | 215     |  |  |  |
| Uppercase Q | Ω       | 118     | 51          | 81      | D8          | 216     |  |  |  |
| Uppercase R | R       | 11–9    | 52          | 82      | D9          | 217     |  |  |  |
| Uppercase S | · s     | 0-2     | 53          | 83      | E2          | 226     |  |  |  |
| Uppercase T | т       | 0-3     | 54          | 84      | E3          | 227     |  |  |  |
| Uppercase U | U       | 0-4     | 55          | 85      | E4          | 228     |  |  |  |
| Uppercase V | V       | 0–5     | 56          | 86      | E5          | 229     |  |  |  |
| Uppercase W | w       | 0–6     | 57          | 87      | E6          | 230     |  |  |  |
| Uppercase X | ×       | 0-7     | 58          | 88      | E7          | 231     |  |  |  |
| Uppercase Y | Y       | 0-8     | 59          | 89      | E8          | 232     |  |  |  |
| Uppercase Z | z       | 0–9     | 5A          | 90      | E9          | 233     |  |  |  |
| Lowercase a | a       | 12-0-1  | 61          | 97      | 81          | 129     |  |  |  |
| Lowercase b | b       | 12-0-2  | 62          | 98      | 82          | 130     |  |  |  |
| Lowercase c | С       | 12-0-3  | 63          | 99      | 83          | 131     |  |  |  |

B-2

Table B—1. Punched Card, ASCII, and EBCDIC Codes (Part 2 of 5)

|             | Printed | Card     | ASC         | 11      | EBC             | DIC     |
|-------------|---------|----------|-------------|---------|-----------------|---------|
| Character   | Symbol  | Punches  | Hexadecimal | Decimal | Hexadecimal     | Decimal |
| Lowercase d | d       | 12-0-4   | 64          | 100     | 84              | 132     |
| Lowercase e | е       | 12-0-5   | 65          | 101     | 85              | 133     |
| Lowercase f | f       | 12-0-6   | 66          | 102     | 86              | 134     |
| Lowercase g | g       | 12-0-7   | 67          | 103     | 87              | 135     |
| Lowercase h | h       | 12-0-8   | 68          | 104     | 88              | 136     |
| Lowercase i | i       | 12-0-9   | 69          | 105     | 89              | 137     |
| Lowercase j | j       | 1211-1   | 6A          | 106     | 91              | 145     |
| Lowercase k | k       | 12-11-2  | 6B          | 107     | 92              | 146     |
| Lowercase I | 1       | 12-11-3  | 6C          | 108     | 93              | 147     |
| Lowercase m | m       | 12-11-4  | 6D          | 109     | 94              | 148     |
| Lowercase n | n       | 12-11-5  | 6E          | 110     | 95              | 149     |
| Lowercase o | О       | 12-11-6  | 6F          | 111     | <sub>.</sub> 96 | 150     |
| Lowercase p | р       | 12-11-7  | 70          | 112     | 97              | 151     |
| Lowercase q | q       | 12-11-8  | 71          | 113     | 98              | 152     |
| Lowercase r | r       | 12-11-9  | 72          | 114     | 99              | 153     |
| Lowercase s | s       | 11-0-2   | 73          | 115     | A2              | 162     |
| Lowercase t | t       | 11-0-3   | 74          | 116     | А3              | 163     |
| Lowercase u | u       | 11-0-4   | 75          | 117     | A4              | 164     |
| Lowercase v | v       | 11-0-5   | 76          | 118     | A5              | 165     |
| Lowercase w | w       | 11-0-6   | 77          | 119     | A6              | 166     |
| Lowercase x | ×       | 11-0-7   | 78          | 120     | A7              | 167     |
| Lowercase y | Y       | 11-0-8   | 79          | 121     | A8              | 168     |
| Lowercase z | z       | 11-0-9   | 7A          | 122     | A9              | 169     |
|             |         | Numerals |             |         |                 |         |
| 0           | 0       | 0        | 30          | 48      | F0              | 240     |
| 1           | 1       | 1        | 31          | 49      | F1              | 241     |
| 2           | 2       | 2        | 32          | 50      | F2              | 242     |
| 3           | 3       | 3        | 33          | 51      | F3              | 243     |
| 4           | 4       | 4        | 34          | 52      | F4              | 244     |
| 5           | 5       | 5        | 35          | 53      | F5              | 245     |
| 6           | 6       | 6        | 36          | 54      | F6              | 246     |

|                          | Printed | Card    | ASC         |         | EBC         | DIC      |
|--------------------------|---------|---------|-------------|---------|-------------|----------|
| Character                | Symbol  | Punches | Hexadecimal | Decimal | Hexadecimal | Decimal  |
| 7                        | 7       | 7       | 37          | 55      | F7          | 247      |
| 8                        | 8       | 8       | 38          | 56      | F8          | 248      |
| 9                        | 9       | 9       | 39          | 57      | F9          | 249      |
|                          |         | Symbols | <u> </u>    |         |             | <u> </u> |
| Exclamation point        | !       | 12-8-7  | 21          | 33      | 4F          | 79       |
| Quotation mark, dieresis | "       | 8–7     | 22          | 34      | 7F          | 127      |
| Number sign, pound sign  | #       | 8–3     | 23          | 35      | 7B          | 123      |
| Dollar sign              | \$      | 11-8-3  | 24          | 36      | 5B          | 91       |
| Percent sign             | %       | 0-8-4   | 25          | 37      | 6C          | 108      |
| Ampersand                | &       | 12      | 26          | 38      | 50          | 80       |
| Apostrophe, acute accent |         | 85      | 27          | 39      | 7D -        | 125      |
| Opening parenthesis      | (       | 12–8–5  | 28          | 40      | 4D          | 77       |
| Closing parenthesis      | )       | 11-8-5  | 29          | 41      | 5D          | 93       |
| Asterisk                 | *       | 11-8-4  | 2A          | 42      | 5C          | 92       |
| Plus sign                | +       | 12-8-6  | 2B          | 43      | 4E          | 78       |
| Comma, cedilla           |         | 0-8-3   | 2C          | 44      | 6B          | 107      |
| Minus sign, hyphen       | _       | 11      | 2D          | 45      | 60          | 96       |
| Period, decimal point    | -       | 12-8-3  | 2E          | 46      | 48          | 75       |
| Slash, virgule, solidus  | /       | 0-1     | 2F          | 47      | 61          | 97       |
| Colon                    | :       | 8-2     | 3A          | 58      | 7A          | 122      |
| Semicolon                | ;       | 11-8-6  | 3B          | 59      | 5E          | 94       |
| Less than                | <       | 12-8-4  | 3C          | 60      | 4C          | 76       |
| Equal sign               | =       | 8–6     | 3D          | 61      | 7E          | 126      |
| Greater than             | >       | 0-8-6   | 3E          | 62      | 6E          | 110      |
| Question mark            | ?       | 0-8-7   | 3F          | 63      | 6F          | 111      |
| Commercial at symbol     | @       | 8-4     | 40          | 64      | 7C          | 124      |
| Opening bracket          | 1       | 12-8-2  | 5B          | 91      | 4A          | 74       |
| Closing bracket          | 1       | 11-8-2  | 5D          | 93      | 5A          | 90       |
| Reverse slash            | \       | 0-8-2   | 5C          | 92      | EO          | 224      |
| Circumflex               | ^       | 11-8-7  | 5E          | 94      | 5F          | 95       |

Table B-1. Punched Card, ASCII, and EBCDIC Codes (Part 4 of 5)

|                 | Printed | Printed Card |             | ASCII   |             | EBCDIC  |  |
|-----------------|---------|--------------|-------------|---------|-------------|---------|--|
| Character       | Symbol  | Punches      | Hexadecimal | Decimal | Hexadecimal | Decimal |  |
| Underline       |         | 0-8-5        | 5F          | 95      | 6D          | 109     |  |
| Grave accent    | ,       | 8-1          | 60          | 96      | 79          | 121     |  |
| Opening brace   | {       | 12-0         | 7B          | 123     | СО          | 192     |  |
| Closing brace   | }       | 11-0         | 7D          | 125     | D0          | 208     |  |
| Vertical line   | 1       | 12-11        | 7C          | 124     | 6A          | 106     |  |
| Overline, tilde | ~       | 11-0-1       | 7E          | 126     | A1          | 161     |  |

|                                 | Card        | ASC         | 11      | EBCDIC      |         |  |  |  |
|---------------------------------|-------------|-------------|---------|-------------|---------|--|--|--|
| Character                       | Punches     | Hexadecimal | Decimal | Hexadecimal | Decimal |  |  |  |
| Nonprintable Characters         |             |             |         |             |         |  |  |  |
| ACK (Acknowledge)               | 0-9-8-6     | 06          | 6       | 2E          | 46      |  |  |  |
| BEL (Bell)                      | 0-9-8-7     | 07          | 7       | 2F          | 47      |  |  |  |
| BS (Backspace)                  | 11-9-6      | 08          | 8       | 16          | 22      |  |  |  |
| CAN (Cancel)                    | 11-9-8      | 18          | 24      | 18          | 24      |  |  |  |
| CR (Carriage return)            | 12-9-8-5    | 0D          | 13      | 0D          | 13      |  |  |  |
| DC1 (Device control 1)          | 11-9-1      | 11          | 17      | 11          | 17      |  |  |  |
| DC2 (Device control 2)          | 11-9-2      | 12          | 18      | 12          | 18      |  |  |  |
| DC3 (Device control 3)          | 11-9-3      | 13          | 19      | 13          | 19      |  |  |  |
| DC4 (Device control 4)          | 9-8-4       | 14          | 20      | 3C          | 60      |  |  |  |
| DEL (Delete)                    | 12-9-7      | 7F          | 127     | 07          | 7       |  |  |  |
| DLE (Data link escape)          | 12-11-9-8-1 | 10          | 16      | 10          | 16      |  |  |  |
| DS (Digit select)               | 11-0-9-8-1  | 80          | 128     | 20          | 32      |  |  |  |
| EM (End of medium)              | 11-9-8-1    | 19          | 25      | 19          | 25      |  |  |  |
| ENQ (Enquiry)                   | 0-9-8-5     | 05          | 5       | 2D          | 45      |  |  |  |
| EOT (End of transmission)       | 9-7         | 04          | 4       | 37          | 55      |  |  |  |
| ESC (Escape)                    | 0-9-7       | 1B          | 27      | 27          | 39      |  |  |  |
| ETB (End of transmission block) | 0-9-6       | 17          | 23      | 26          | 38      |  |  |  |
| ETX (End of text)               | 12-9-3      | 03          | 3       | 03          | 3       |  |  |  |
| FF (Form feed)                  | 12-9-8-4    | ос          | 12      | oc          | 12      |  |  |  |
| FS (File separator)             | 11-9-8-4    | 1C          | 28      | 1C          | 28      |  |  |  |

Table B—1. Punched Card, ASCII, and EBCDIC Codes (Part 5 of 5)

| Character                  | Card       | ASCI        | ı       | EBCDIC      |         |  |
|----------------------------|------------|-------------|---------|-------------|---------|--|
| Character                  | Punches    | Hexadecimal | Decimal | Hexadecimal | Decimal |  |
| FS (Field separator)       | 0-9-2      | 82          | 130     | 22          | 34      |  |
| GS (Group separator)       | 11-9-8-5   | 1D          | 29      | 1D          | 29      |  |
| HT (Horizontal tabulation) | 12-9-5     | 09          | 9       | 05          | 5       |  |
| LF (Line feed)             | 0-9-5      | 0A          | 10      | 25          | 37      |  |
| NAK (Negative acknowledge) | 9-8-5      | 15          | 21      | 3D          | 61      |  |
| NUL (Null)                 | 12-0-9-8-1 | 00          | 0       | 00          | 0       |  |
| RS (Record separator)      | 11-9-8-6   | 1E          | 30      | 1E          | 30      |  |
| SI (Shift in)              | 12-9-8-7   | 0F          | 15      | 0F          | 15      |  |
| SO (Shift out)             | 12-9-8-6   | 0E          | 14      | 0E          | 14      |  |
| SOH (Start of heading)     | 12-9-1     | 01          | 1       | 01          | 1       |  |
| SOS (Significance start)   | 0-9-1      | 81          | 129     | 21          | 33      |  |
| SP (Space)                 |            | 20          | 32      | 40          | 64      |  |
| STX (Start of text)        | 12-9-2     | 02          | 2       | 02          | 2       |  |
| SUB (Substitute)           | 9-8-7      | 1A          | 26      | 3F          | 63      |  |
| SYN (Synchronous idle)     | 9–2        | 16          | 22      | 32          | 50      |  |
| US (Unit separator)        | 11-9-8-7   | 1F          | 31      | 1F          | 31      |  |
| VT (Vertical tabulation)   | 12-9-8-3   | 0В          | 11      | ОВ          | 11      |  |

Table B—2. 90/30 EBCDIC Code Chart

|                  |      |      |      |       |      |            |            | Bit F | osition    | ns O, 1,   | 2, 3 |      |      |      |      |            |      |
|------------------|------|------|------|-------|------|------------|------------|-------|------------|------------|------|------|------|------|------|------------|------|
|                  |      | 0000 | 0001 | 0010  | 0011 | 0100       | 0101       | 0110  | 0111       | 1000       | 1001 | 1010 | 1011 | 1100 | 1101 | 1110       | 1111 |
|                  | 0000 | NUL  | DLE  | DS(1) |      | SP         | &          | _     |            |            |      |      |      | {@   | }@   | \ <b>④</b> | 0    |
|                  | 0001 | son  | DC1  | sos   |      |            |            | 1     |            | a <b>4</b> | j    | ~4   |      | Α    | J    |            | 1    |
|                  | 0010 | STX  |      | FS(1) | SYN  |            |            |       |            | b          | k    | s    |      | В    | κ    | s          | 2    |
|                  | 0011 | ЕТХ  | DC3  |       |      |            |            |       |            | С          | 1    | t    |      | С    | L    | т          | 3    |
|                  | 0100 |      |      |       |      |            |            |       |            | d          | m    | u    |      | D    | м    | U          | 4    |
|                  | 0101 | нт   |      | LF    |      |            |            |       |            | е          | n    | v    |      | E    | N    | V          | 5    |
| n:               | 0110 |      | BS   | ЕТВ   |      |            |            |       |            | f          | o    | w    |      | F    | 0    | w          | 6    |
| Bit<br>Positions | 0111 | DEL  |      | ESC   | ЕОТ  |            |            |       |            | g          | р    | x    |      | G    | P    | ×          | 7    |
| 4, 5, 6, 7       | 1000 |      | CAN  |       |      |            |            |       |            | h          | q    | У    |      | н    | Q    | Υ          | 8    |
|                  | 1001 |      | EM   |       |      |            |            |       | , <b>④</b> | i          | r    | z    |      | 1    | R    | z          | 9    |
|                  | 1010 |      |      |       |      | ]          | ]          | ¦③    | :          |            |      |      |      |      |      |            |      |
|                  | 1011 | VT   |      |       |      | •          | \$         | ,     | #          |            |      |      |      |      |      |            |      |
|                  | 1100 | FF   | FS   |       | DC4  | <b>\</b>   | *          | %     | 0          |            |      |      |      |      |      |            |      |
|                  | 1101 | CR   | GS   | ENQ   | NAK  | (          | )          |       | ,          |            |      |      |      |      |      |            |      |
|                  | 1110 | so   | RS   | ACK   |      | +          | ;          | >     | =          |            |      |      |      |      |      |            |      |
|                  | 1111 | SI   | us   | BEL   | SUB  | <u>,</u> ② | <b>_</b> @ | ?     | ,,         |            |      |      |      |      |      |            |      |

#### NOTES:

EBCDIC bits are numbered from the left in ascending numerical order: 0 1 2 3 4 5 6 7. Some graphic card code and hexadecimal assignments may differ depending on the device, language, application, and installation policy.

- 1 DS, SOS, FS are the control characters for the EDIT instruction and have been assigned for ASCII mode processing so as not to conflict with the corresponding character positions previously assigned in the EBCDIC chart. As these characters are not outside the range as defined in American National Standard, X3.4 1968, they must not appear in external storage media, such as ANSI standard tapes. This presents no difficulty due to the nature of the EDIT instruction.
- The following optional graphics can be substituted in the character set:

∧ for ☐

for!

3 For 63-character printers, the following substitution is made:

\for !

The lowercase alphabet and indicated graphics are introduced by use of the type 0768-02 printer, which prints a 94-character set.

Table B-3. ASCII Character Code Chart

|            |      |     | Bit Positions 7, 6, 5 |            |     |     |            |     |     |  |  |  |  |  |
|------------|------|-----|-----------------------|------------|-----|-----|------------|-----|-----|--|--|--|--|--|
|            |      | 000 | 001                   | 010        | 011 | 100 | 101        | 110 | 111 |  |  |  |  |  |
|            | 0000 | NUL | DLE                   | SP         | 0   | @   | Р          | ,   | р   |  |  |  |  |  |
|            | 0001 | soн | DC1                   | <u>, ①</u> | 1   | Α   | a          | а   | q   |  |  |  |  |  |
|            | 0010 | STX | DC2                   | <b>"</b> . | 2   | В   | R          | b   | r   |  |  |  |  |  |
|            | 0011 | ETX | DC3                   | #          | 3   | С   | s          | С   | s   |  |  |  |  |  |
|            | 0100 | EOT | DC4                   | \$         | 4   | D   | т          | d   | t   |  |  |  |  |  |
| :          | 0101 | ENQ | NAK                   | %          | 5   | E   | U          | е   | U   |  |  |  |  |  |
| Bit        | 0110 | ACK | SYN                   | &          | 6   | F   | ٧          | f   | v   |  |  |  |  |  |
| Positions  | 0111 | BEL | ЕТВ                   | ,          | 7   | G   | w          | g   | w   |  |  |  |  |  |
| 4, 3, 2, 1 | 1000 | BS  | CAN                   | (          | 8   | н   | ×          | h   | ×   |  |  |  |  |  |
|            | 1001 | нт  | EM                    | )          | 9   | 1   | Y          | í   | У   |  |  |  |  |  |
|            | 1010 | LF  | SUB                   | *          | :   | J   | Z          | j   | Z   |  |  |  |  |  |
|            | 1011 | VT  | ESC                   | +          | ;   | К   | [          | k   | {   |  |  |  |  |  |
|            | 1100 | FF  | FS                    | ,          | <   | L   | \          | I   |     |  |  |  |  |  |
|            | 1101 | CR  | GS                    | _          | =   | М   | ]          | m   | }   |  |  |  |  |  |
|            | 1110 | so  | RS                    | ·          | >   | N   | <b>∧</b> ① | n   | ~   |  |  |  |  |  |
|            | 1111 | SI  | US                    | 1          | ?   | 0   |            | 0   | DEL |  |  |  |  |  |
|            |      |     |                       |            |     | 2   |            |     | 3   |  |  |  |  |  |
|            |      |     |                       |            |     |     | <u>(4)</u> |     |     |  |  |  |  |  |

## NOTES:

ASCII bits are numbered from the left in descending numerical order: 7 6 5 4 3 2 1. Some graphic card code and hexadecimal assignments may differ depending on the device, language, application, and installation policy.

1 The following optional graphics can be substituted 2 Sixty-three printable character set.

in the following set:

3 Graphics available by use of the type 0768-02 printer which prints a 94-character set (DEL is not a graphic)

 $\neg$  for  $\triangle$ for!

4 Ninety-four printable character set.

## **Control Character Mnemonics**

| _ | Acknowledge      | ENQ                                                                                                                                                                                                                                                         | _                                                                                                                                                                 | Enquiry                                                                                                                                             | SI                                                                                                                                                                                                                                                                                                                                                                               | _                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          | Shift in                                                                                                                                                                                                                                                                                                                                                   |
|---|------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| _ | Beil             | EOT                                                                                                                                                                                                                                                         | -                                                                                                                                                                 | End of transmission                                                                                                                                 | SO                                                                                                                                                                                                                                                                                                                                                                               | -                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          | Shift out                                                                                                                                                                                                                                                                                                                                                  |
| _ | Backspace        | ESC                                                                                                                                                                                                                                                         | _                                                                                                                                                                 | Escape                                                                                                                                              | SOH                                                                                                                                                                                                                                                                                                                                                                              | _                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          | Start of heading                                                                                                                                                                                                                                                                                                                                           |
| _ | Cancel           | ETB                                                                                                                                                                                                                                                         | _                                                                                                                                                                 | End of transmission block                                                                                                                           | SOS                                                                                                                                                                                                                                                                                                                                                                              | _                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          | Start of significance                                                                                                                                                                                                                                                                                                                                      |
|   | Carriage return  | ETX                                                                                                                                                                                                                                                         | _                                                                                                                                                                 | End of text                                                                                                                                         | SP                                                                                                                                                                                                                                                                                                                                                                               |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            | Space                                                                                                                                                                                                                                                                                                                                                      |
|   | Device control 1 | FF                                                                                                                                                                                                                                                          | _                                                                                                                                                                 | Form feed                                                                                                                                           | STX                                                                                                                                                                                                                                                                                                                                                                              |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            | Start of text                                                                                                                                                                                                                                                                                                                                              |
| _ | Device control 2 | FS                                                                                                                                                                                                                                                          | _                                                                                                                                                                 | Field separator                                                                                                                                     | SUB                                                                                                                                                                                                                                                                                                                                                                              | _                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          | Substitute                                                                                                                                                                                                                                                                                                                                                 |
| - | Device control 3 | GS                                                                                                                                                                                                                                                          | _                                                                                                                                                                 | Group separator                                                                                                                                     | SYN                                                                                                                                                                                                                                                                                                                                                                              | -                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          | Synchronous idle                                                                                                                                                                                                                                                                                                                                           |
| - | Device control 4 | HT                                                                                                                                                                                                                                                          | _                                                                                                                                                                 | Horizontal tab                                                                                                                                      | US                                                                                                                                                                                                                                                                                                                                                                               | -                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          | Unit separator                                                                                                                                                                                                                                                                                                                                             |
| _ | Delete           | LF                                                                                                                                                                                                                                                          | _                                                                                                                                                                 | Line field                                                                                                                                          | VT                                                                                                                                                                                                                                                                                                                                                                               |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            | Vertical tab                                                                                                                                                                                                                                                                                                                                               |
| - | Data link escape | NAK                                                                                                                                                                                                                                                         | -                                                                                                                                                                 | Negative acknowledge                                                                                                                                |                                                                                                                                                                                                                                                                                                                                                                                  |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |                                                                                                                                                                                                                                                                                                                                                            |
|   |                  | <ul> <li>Acknowledge</li> <li>Bell</li> <li>Backspace</li> <li>Cancel</li> <li>Carriage return</li> <li>Device control 1</li> <li>Device control 2</li> <li>Device control 3</li> <li>Device control 4</li> <li>Delete</li> <li>Data link escape</li> </ul> | - Bell EOT - Backspace ESC - Cancel ETB - Carriage return ETX - Device control 1 FF - Device control 2 FS - Device control 3 GS - Device control 4 HT - Delete LF | - Bell EOT Backspace ESC Cancel ETB Carriage return ETX Device control 1 FF Device control 2 FS Device control 3 GS Device control 4 HT Delete LF - | <ul> <li>Bell</li> <li>Backspace</li> <li>Cancel</li> <li>Device control 3</li> <li>Device control 4</li> <li>Delete</li> <li>EOT - End of transmission</li> <li>Escape</li> <li>End of transmission block</li> <li>Erd of text</li> <li>End of text</li> <li>Form feed</li> <li>Field separator</li> <li>Group separator</li> <li>Horizontal tab</li> <li>Line field</li> </ul> | <ul> <li>Bell</li> <li>Backspace</li> <li>Cancel</li> <li>Carriage return</li> <li>Device control 3</li> <li>Device control 4</li> <li>Device control 4</li> <li>Delete</li> <li>EOT - End of transmission</li> <li>Escape</li> <li>End of transmission block</li> <li>SOS</li> <li>End of text</li> <li>SP</li> <li>Form feed</li> <li>STX</li> <li>Field separator</li> <li>SUB</li> <li>Group separator</li> <li>SYN</li> <li>US</li> <li>Delete</li> <li>LF</li> <li>Line field</li> <li>VT</li> </ul> | - Bell EOT - End of transmission SO - Backspace ESC - Escape SOH - Cancel ETB - End of transmission block SOS - Carriage return ETX - End of text SP - Device control 1 FF - Form feed STX - Device control 2 FS - Field separator SUB - Device control 3 GS - Group separator SYN - Device control 4 HT - Horizontal tab US - Delete LF - Line field VT - |

DS - Digit select NUL - Null

ΕM End of medium RS Record separator

**Appendix C. Math References** 

|                                       |   |   | AND THE PERSON NAMED IN STREET        | ************************************** |           |
|---------------------------------------|---|---|---------------------------------------|----------------------------------------|-----------|
|                                       |   |   |                                       |                                        |           |
|                                       |   |   |                                       | •                                      |           |
|                                       |   |   |                                       |                                        |           |
|                                       |   |   |                                       |                                        |           |
|                                       |   |   | •                                     |                                        | Transport |
|                                       |   |   |                                       |                                        |           |
|                                       |   |   |                                       |                                        |           |
|                                       |   |   |                                       |                                        |           |
|                                       |   |   |                                       |                                        |           |
|                                       |   |   |                                       |                                        |           |
|                                       |   |   |                                       |                                        |           |
|                                       |   |   |                                       |                                        |           |
|                                       |   |   |                                       |                                        | •         |
|                                       |   |   |                                       |                                        |           |
|                                       |   |   |                                       |                                        |           |
|                                       |   |   |                                       |                                        |           |
|                                       |   |   |                                       |                                        |           |
| · · · · · · · · · · · · · · · · · · · |   |   |                                       |                                        |           |
|                                       |   |   |                                       |                                        |           |
|                                       |   |   |                                       |                                        |           |
|                                       |   | • |                                       |                                        |           |
|                                       |   |   |                                       |                                        |           |
|                                       |   |   |                                       |                                        |           |
|                                       |   |   |                                       |                                        |           |
|                                       |   |   |                                       |                                        |           |
|                                       |   | 7 |                                       |                                        |           |
|                                       |   |   |                                       |                                        |           |
|                                       |   |   | ·                                     |                                        |           |
|                                       | · |   |                                       |                                        |           |
|                                       |   |   |                                       |                                        |           |
|                                       |   |   |                                       |                                        |           |
|                                       |   |   |                                       |                                        |           |
|                                       |   |   |                                       |                                        |           |
|                                       |   |   |                                       |                                        |           |
|                                       |   |   |                                       |                                        |           |
|                                       |   |   |                                       |                                        |           |
|                                       |   |   |                                       |                                        |           |
|                                       |   |   |                                       |                                        |           |
|                                       |   |   |                                       |                                        |           |
|                                       | , |   |                                       | •                                      | المستنب   |
|                                       |   |   |                                       | *                                      |           |
|                                       |   |   | · · · · · · · · · · · · · · · · · · · |                                        |           |
|                                       | , |   |                                       | :                                      | ě.        |
|                                       |   | , |                                       |                                        |           |
| · ·                                   |   |   |                                       |                                        |           |

Table C—1. Comparison for Numeric Expressions

| Type of Number             | Examples                      | Decimal<br>Values |
|----------------------------|-------------------------------|-------------------|
| Character form (unpacked)  | F 5 F 0 F 0                   | 500               |
| Zoned decimal (+)          | F 5 F 0 C 0                   | +500              |
| Zoned decimal (—)          | F 5 F 0 D 0                   | -500              |
| Packed decimal (+ only)    | 5 0 0 F                       | +500              |
| Packed decimal, signed (+) | 5 0 0 C                       | +500              |
| Packed decimal, signed (—) | 5 0 0 D                       | 500               |
| Hexadecimal (+ only)       | 0 1 F 4                       | +500              |
| Floating point (+)         | 4   3   1   F   4   0   0   0 | +500              |
| Floating point (—)         | C 3 1 F 4 0 0 0               | 500               |
| Binary (+ only)            | 0000 0001 1111 0100           | +500              |
| Binary (+ only)            | 1111 1110 0000 1100           | +65,036           |
| Fixed point (+)            | 0000   0001   1111   0100     | +500              |
| Fixed point ()             | 1111 1110 0000 1100           | -500              |

Table C-2. Hexadecimal-Decimal Integer Conversion (Part 1 of 4)

| 1                    |              |              |              |              |              |              |              |              |              |              | •            |              |              |              |              |              |
|----------------------|--------------|--------------|--------------|--------------|--------------|--------------|--------------|--------------|--------------|--------------|--------------|--------------|--------------|--------------|--------------|--------------|
|                      | 0            | 1            | 2            | 3            | 4            | 5            | 6            | 7            | 8            | 9            | Α            | В            | С            | D            | E            | F            |
| 00                   | 0000         | 0001         | 0002         | 0003         | 0004         | 0005         | 0006         | 0007         | 0008         | 0009         | 0010         | 0011         | 0012         | 0013         | 0014         | 0015         |
| 01                   | 0016         | 0017         | 0018         | 0019<br>0035 | 0020<br>0036 | 0021<br>0037 | 0022<br>0038 | 0023<br>0039 | 0024<br>0040 | 0025<br>0041 | 0026<br>0042 | 0027<br>0043 | 0028<br>0044 | 0029<br>0045 | 0030<br>0046 | 0031<br>0047 |
| 02                   | 0032<br>0048 | 0033<br>0049 | 0034<br>0050 | 0035         | 0052         | 0057         | 0058         | 0055         | 0056         | 0057         | 0058         | 0059         | 0060         | 0061         | 0062         | 0063         |
| 04                   | 0064         | 0065         | 0066         | 0067         | 0068         | 0069         | 0070         | 0071         | 0072         | 0073         | 0074         | 0075         | 0076         | 0077         | 0078         | 0079         |
| 05                   | 0080         | 0081         | 0082         | 0083         | 0084         | 0085         | 0086         | 0087         | 0088<br>0104 | 0089<br>0105 | 0090<br>0106 | 0091<br>0107 | 0092<br>0108 | 0093<br>0109 | 0094<br>0110 | 0095<br>0111 |
| 06                   | 0096<br>0112 | 0097<br>0113 | 0098<br>0114 | 0099<br>0115 | 0100<br>0116 | 0101<br>0117 | 0102<br>0118 | 0103<br>0119 | 0120         | 0105         | 0100         | 0123         | 0108         | 0105         | 0116         | 0127         |
| 08                   | 0128         | 0129         | 0130         | 0131         | 0132         | 0133         | 0134         | 0135         | 0136         | 0137         | 0138         | 0139         | 0140         | 0141         | 0142         | 0143         |
| 09                   | 0144         | 0145         | 0146         | 0147         | 0148         | 0149         | 0150         | 0151         | 0152         | 0153         | 0154         | 0155         | 0156         | 0157         | 0158         | 0159         |
| OA<br>OB             | 0160<br>0176 | 0161<br>0177 | 0162<br>0178 | 0163<br>0179 | 0164<br>0180 | 0165<br>0181 | 0166<br>0182 | 0167<br>0183 | 0168<br>0184 | 0169<br>0185 | 0170<br>0186 | 0171<br>0187 | 0172<br>0188 | 0173<br>0189 | 0174<br>0190 | 0175<br>0191 |
| oc l                 | 0170         | 0193         | 0176         | 0195         | 0196         | 0197         | 0198         | 0199         | 0200         | 0201         | 0202         | 0203         | 0204         | 0205         | 0206         | 0207         |
| OD.                  | 0208         | 0209         | 0210         | 0211         | 0212         | 0213         | 0214         | 0215         | 0216         | 0217         | 0218         | 0219         | 0220         | 0221         | 0222         | 0223         |
| OE<br>O <del>F</del> | 0224<br>0240 | 0225<br>0241 | 0226<br>0242 | 0227<br>0243 | 0228<br>0244 | 0229<br>0245 | 0230<br>0246 | 0231<br>0247 | 0232<br>0248 | 0233<br>0249 | 0234<br>0250 | 0235<br>0251 | 0236<br>0252 | 0237<br>0253 | 0238<br>0254 | 0239<br>0255 |
|                      | 0240         | 0241         | 0242         | 0243         | 0244         | 0245         |              | <u> </u>     |              |              |              | <del> </del> |              | -            | -            | <del> </del> |
|                      | 0            | 1            | 2            | 3            | 4            | 5            | 6            | 7            | 8            | 9            | A            | В            | С            | D            | E            | F            |
| 10                   | 0256         | 0257         | 0258         | 0259         | 0260         | 0261         | 0262         | 0263         | 0264         | 0265         | 0266         | 0267         | 0268         | 0269         | 0270         | 0271         |
| 11                   | 0272         | 0273         | 0274         | 0275         | 0276<br>0292 | 0277<br>0293 | 0278<br>0294 | 0279<br>0295 | 0280<br>0296 | 0281<br>0297 | 0282<br>0298 | 0283<br>0299 | 0284<br>0300 | 0285<br>0301 | 0286<br>0302 | 0287<br>0303 |
| 12                   | 0288<br>0304 | 0289<br>0305 | 0290<br>0306 | 0291<br>0307 | 0308         | 0309         | 0294         | 0295         | 0296         | 0297         | 0298         | 0299         | 0300         | 0301         | 0302         | 0303         |
| 14                   | 0320         | 0321         | 0322         | 0323         | 0324         | 0325         | 0326         | 0327         | 0328         | 0329         | 0330         | 0331         | 0332         | 0333         | 0334         | 0335         |
| 15                   | 0336         | 0337         | 0338         | 0339         | 0340         | 0341         | 0342         | 0343         | 0344         | 0345         | 0346         | 0347         | 0348         | 0349         | 0350         | 0351         |
| 16                   | 0352<br>0368 | 0353<br>0369 | 0354<br>0370 | 0355<br>0371 | 0356<br>0372 | 0357<br>0373 | 0358<br>0374 | 0359<br>0375 | 0360<br>0376 | 0361<br>0377 | 0362<br>0378 | 0363<br>0379 | 0364<br>0380 | 0365<br>0381 | 0366<br>0382 | 0367<br>0383 |
| 18                   | 0384         | 0385         | 0376         | 0371         | 0372         | 0379         | 0390         | 0375         | 0392         | 0393         | 0394         | 0395         | 0396         | 0397         | 0398         | 0399         |
| 19                   | 0400         | 0401         | 0402         | 0403         | 0404         | 0405         | 0406         | 0407         | 0408         | 0409         | 0410         | 0411         | 0412         | 0413         | 0414         | 0415         |
| 1A                   | 0416         | 0417         | 0418         | 0419         | 0420         | 0421         | 0422         | 0423         | 0424         | 0425         | 0426         | 0427         | 0428         | 0429         | 0430         | 0431         |
| 1B<br>1C             | 0432<br>0448 | 0433<br>0449 | 0434<br>0450 | 0435<br>0451 | 0436<br>0452 | 0437<br>0453 | 0438<br>0454 | 0439<br>0455 | 0440<br>0456 | 0441<br>0457 | 0442<br>0458 | 0443<br>0459 | 0444<br>0460 | 0445<br>0461 | 0446<br>0462 | 0447<br>0463 |
| 10                   | 0448         | 0465         | 0466         | 0467         | 0468         | 0469         | 0470         | 0471         | 0472         | 0473         | 0474         | 0475         | 0476         | 0477         | 0478         | 0479         |
| 1E                   | 0480         | 0481         | 0482         | 0483         | 0484         | 0485         | 0486         | 0487         | 0488         | 0489         | 0490         | 0491         | 0492         | 0493         | 0494         | 0495         |
| 1F                   | 0496         | 0497         | 0498         | 0499         | 0500         | 0501         | 0502         | 0503         | 0504         | 0505         | 0506         | 0507         | 0508         | 0509         | 0510         | 0511         |
|                      | 0            | 1            | 2            | 3            | 4            | 5            | 6            | 7            | 8            | 9_           | Α            | В            | С            | D            | E            | F            |
| 20                   | 0512         | 0513         | 0514         | 0515         | 0516         | 0517         | 0518         | 0519         | 0520         | 0521         | 0522         | 0523         | 0524         | 0525         | 0526         | 0527         |
| 21                   | 0528         | 0529         | 0530         | 0531         | 0532         | 0533         | 0534         | 0535         | 0536         | 0537         | 0538         | 0539         | 0540         | 0541         | 0542         | 0543         |
| 22                   | 0544<br>0560 | 0545<br>0561 | 0546         | 0547<br>0563 | 0548<br>0564 | 0549<br>0565 | 0550<br>0566 | 0551<br>0567 | 0552<br>0568 | 0553<br>0569 | 0554<br>0570 | 0555<br>0571 | 0556<br>0572 | 0557<br>0573 | 0558<br>0574 | 0559<br>0575 |
| 23                   | 0576         | 0577         | 0562<br>0578 | 0579         | 0580         | 0581         | 0582         | 0583         | 0584         | 0585         | 0576         | 0587         | 0572         | 0589         | 0590         | 0573         |
| 25                   | 0592         | 0593         | 0594         | 0595         | 0596         | 0597         | 0598         | 0599         | 0600         | 0601         | 0602         | 0603         | 0604         | 0605         | 0606         | 0607         |
| 26                   | 0608         | 0609         | 0610         | 0611         | 0612         | 0613         | 0614         | 0615         | 0616         | 0617         | 0618         | 0619         | 0620         | 0621         | 0622         | 0623         |
| 27<br>28             | 0624<br>0640 | 0625         | 0626         | 0627         | 0628<br>0644 | 0629<br>0645 | 0630<br>0646 | 0631<br>0647 | 0632<br>0648 | 0633<br>0649 | 0634<br>0650 | 0635<br>0651 | 0636<br>0652 | 0637<br>0653 | 0638<br>0654 | 0639<br>0655 |
| 29                   | 0656         | 0641<br>0657 | 0642<br>0658 | 0643<br>0659 | 0660         | 0661         | 0662         | 0663         | 0664         | 0665         | 0666         | 0667         | 0668         | 0669         | 0670         | 0671         |
| 2A                   | 0672         | 0673         | 0674         | 0675         | 0676         | 0677         | 0678         | 0679         | 0680         | 0681         | 0682         | 0683         | 0684         | 0685         | 0686         | 0687         |
| 28                   | 0688         | 0689         | 0690         | 0691         | 0692         | 0693         | 0694         | 0695         | 0696         | 0697         | 0698         | 0699         | 0700         | 0701         | 0702         | 0703         |
| 2C<br>2D             | 0704<br>0720 | 0705<br>0721 | 0706<br>0722 | 0707<br>0723 | 0708<br>0724 | 0709<br>0725 | 0710<br>0726 | 0711<br>0727 | 0712<br>0728 | 0713<br>0729 | 0714<br>0730 | 0715<br>0731 | 0716<br>0732 | 0717<br>0733 | 0718<br>0734 | 0719<br>0735 |
| 2E                   | 0726         | 0721         | 0722         | 0723         | 0740         | 0725         | 0742         | 0743         | 0744         | 0745         | 0746         | 0747         | 0732         | 0749         | 0750         | 0751         |
| 2F                   | 0752         | 0753         | 0754         | 0755         | 0756         | 0757         | 0758         | 0759         | 0760         | 0761         | 0762         | 0763         | 0764         | 0765         | 0766         | 0767         |
|                      | 0            | 1            | 2            | 3            | 4            | 5            | 6            | 7            | 8            | 9            | A            | В            | С            | D            | E            | F            |
| 30                   | 0768         | 0769         | 0770         | 0771         | 0772         | 0773         | 0774         | 0775         | 0776         | 0777         | 0778         | 0779         | 0780         | 0781         | 0782         | 0783         |
| 31                   | 0784         | 0785         | 0786         | 0787         | 0788         | 0789         | 0790         | 0791         | 0792         | 0793         | 0794         | 0795         | 0796         | 0797         | 0798         | 0799         |
| 32                   | 0800<br>0816 | 0801<br>0817 | 0802<br>0818 | 0803<br>0819 | 0804<br>0820 | 0805<br>0821 | 0806<br>0822 | 0807<br>0823 | 0808<br>0824 | 0809<br>0825 | 0810<br>0826 | 0811<br>0827 | 0812<br>0828 | 0813<br>0829 | 0814<br>0830 | 0815<br>0831 |
| 34                   | 0832         | 0833         | 0834         | 0835         | 0836         | 0837         | 0838         | 0839         | 0840         | 0841         | 0842         | 0843         | 0844         | 0845         | 0846         | 0847         |
| 35                   | 0848         | 0849         | 0850         | 0851         | 0852         | 0853         | 0854         | 0855         | 0856         | 0857         | 0858         | 0859         | 0860         | 0861         | 0862         | 0863         |
| 36                   | 0864         | 0865         | 0866         | 0867         | 0868         | 0869         | 0870         | 0871         | 0872         | 0873         | 0874         | 0875         | 0876         | 0877         | 0878         | 0879         |
| 37<br>38             | 0880<br>0896 | 0881<br>0897 | 0882<br>0898 | 0883<br>0899 | 0884<br>0900 | 0885<br>0901 | 0886<br>0902 | 0887<br>0903 | 0888<br>0904 | 0889<br>0905 | 0890<br>0906 | 0891<br>0907 | 0892<br>0908 | 0893<br>0909 | 0894<br>0910 | 0895<br>0911 |
| 39                   | 0912         | 0913         | 0914         | 0915         | 0916         | 0917         | 0902         | 0919         | 0920         | 0903         | 0922         | 0923         | 0924         | 0925         | 0926         | 0927         |
| 3A                   | 0928         | 0929         | 0930         | 0931         | 0932         | 0933         | 0934         | 0935         | 0936         | 0937         | 0938         | 0939         | 0940         | 0941         | 0942         | 0943         |
| 38                   | 0944         | 0945         | 0946         | 0947         | 0948         | 0949         | 0950         | 0951         | 0952         | 0953         | 0954         | 0955         | 0956         | 0957<br>0973 | 0958<br>0974 | 0959<br>0975 |
| 3C<br>3D             | 0960<br>0976 | 0961<br>0977 | 0962<br>0978 | 0963<br>0979 | 0964<br>0980 | 0965<br>0981 | 0966<br>0982 | 0967<br>0983 | 0968<br>0984 | 0969<br>0985 | 0970<br>0986 | 0971<br>0987 | 0972<br>0988 | 0973         | 0974         | 0975         |
| 3E                   | 0992         | 0993         | 0994         | 0995         | 0996         | 0997         | 0998         | 0999         | 1000         | 1001         | 1002         | 1003         | 1004         | 1005         | 1006         | 1007         |
| 3F                   | 1008         | 1009         | 1010         | 1011         | 1012         | 1013         | 1014         | 1015         | 1016         | 1017         | 1018         | 1019         | 1020         | 1021         | 1022         | 1023         |

Table C—2. Hexadecimal-Decimal Integer Conversion (Part 2 of 4)

|             | 0            | 1              | 2            | 3            | 4            | 5            | 6            | 7            | 8                    | 9            | Α_           | В            | С            | D            | E            | F            |
|-------------|--------------|----------------|--------------|--------------|--------------|--------------|--------------|--------------|----------------------|--------------|--------------|--------------|--------------|--------------|--------------|--------------|
| 40          | 1024         | 1025           | 1026         | 1027         | 1028         | 1029         | 1030         | 1031         | 1032                 | 1033         | 1034         | 1035         | 1036         | 1037         | 1038         | 1039         |
| 41          | 1040         | 1041           | 1042         | 1043         | 1044         | 1045         | 1046         | 1047         | 1048                 | 1049         | 1050         | 1051         | 1052         | 1053         | 1054         | 1055         |
| 42          | 1056         | 1057           | 1058         | 1059         | 1060         | 1061<br>1077 | 1062         | 1063         | 1064<br>1080         | 1065<br>1081 | 1066<br>1082 | 1067<br>1083 | 1068<br>1084 | 1069<br>1085 | 1070<br>1086 | 1071<br>1087 |
| 43<br>44    | 1072<br>1088 | 1073<br>1089   | 1074<br>1090 | 1075<br>1091 | 1076<br>1092 | 1077         | 1078<br>1094 | 1079<br>1095 | 1096                 | 1081         | 1098         | 1099         | 1100         | 1101         | 1102         | 1103         |
| 45          | 1104         | 1105           | 1106         | 1107         | 1108         | 1109         | 1110         | 1111         | 1112                 | 1113         | 1114         | 1115         | 1116         | 1117         | 1118         | 1119         |
| 46          | 1120         | 1121           | 1122         | 1123         | 1124         | 1125         | 1126         | 1127         | 1128                 | 1129         | 1130         | 1131         | 1132         | 1133         | 1134         | 1135         |
| 47          | 1136         | 1137           | 1138         | 1139         | 1140         | 1141         | 1142         | 1143         | 1144                 | 1145         | 1146         | 1147         | 1148         | 1149         | 1150         | 1151         |
| 48<br>49    | 1152<br>1168 | 1153 .<br>1169 | 1154<br>1170 | 1155<br>1171 | 1156<br>1172 | 1157<br>1173 | 1158<br>1174 | 1159<br>1175 | 1160<br>1176         | 1161<br>1177 | 1162<br>1178 | 1163<br>1179 | 1164<br>1180 | 1165<br>1181 | 1166<br>1182 | 1167<br>1183 |
| 4A          | 1184         | 1185           | 1186         | 1187         | 1188         | 1189         | 1190         | 1191         | 1192                 | 1193         | 1194         | 1195         | 1196         | 1197         | 1198         | 1199         |
| 48          | 1200         | 1201           | 1202         | 1203         | 1204         | 1205         | 1206         | 1207         | 1208                 | 1209         | 1210         | 1211         | 1212         | 1213         | 1214         | 1215         |
| 4C          | 1216         | 1217           | 1218         | 1219         | 1220         | 1221         | 1222         | 1223         | 1224                 | 1225         | 1226         | 1227         | 1228         | 1229         | 1230         | 1231         |
| 4D<br>4E    | 1232<br>1248 | 1233<br>1249   | 1234<br>1250 | 1235<br>1251 | 1236<br>1252 | 1237<br>1253 | 1238<br>1254 | 1239<br>1255 | 1240<br>1256         | 1241<br>1257 | 1242<br>1258 | 1243<br>1259 | 1244<br>1260 | 1245<br>1261 | 1246<br>1262 | 1247<br>1263 |
| 4F          | 1264         | 1265           | 1266         | 1267         | 1268         | 1269         | 1270         | 1271         | 1272                 | 1273         | 1274         | 1275         | 1276         | 1277         | 1278         | 1279         |
|             | 0            | 1              | 2            | 3            | 4            | 5            | 6            | 7            | 8                    | 9            | А            | В            | С            | D            | E            | F            |
| 50          | 1280         | 1281           | 1282         | 1283         | 1284         | 1285         | 1286         | 1287         | 1288                 | 1289         | 1290         | 1291         | 1292         | 1293         | 1294         | 1295         |
| 51          | 1296         | 1297           | 1298         | 1299         | 1300         | 1301         | 1302         | 1303         | 1304                 | 1305         | 1306         | 1307         | 1308         | 1309         | 1310         | 1311         |
| 52          | 1312         | 1313           | 1314         | 1315         | 1316         | 1317         | 1318         | 1319         | 1320                 | 1321         | 1322         | 1323         | 1324         | 1325         | 1326         | 1327         |
| 53          | 1328         | 1329           | 1330         | 1331         | 1332         | 1333         | 1334         | 1335         | 1336                 | 1337         | 1338         | 1339         | 1340         | 1341         | 1342         | 1343         |
| 54<br>55    | 1344<br>1360 | 1345<br>1361   | 1346<br>1362 | 1347<br>1363 | 1348<br>1364 | 1349<br>1365 | 1350<br>1366 | 1351<br>1367 | 1352<br>1368         | 1353<br>1369 | 1354<br>1370 | 1355<br>1371 | 1356<br>1372 | 1357<br>1373 | 1358<br>1374 | 1359<br>1375 |
| 56          | 1360         | 1361           | 1362         | 1363         | 1364         | 1381         | 1382         | 1383         | 1388                 | 1385         | 1386         | 1371         | 1388         | 1389         | 1374         | 1375         |
| 57          | 1392         | 1393           | 1394         | 1395         | 1396         | 1397         | 1398         | 1399         | 1400                 | 1401         | 1402         | 1403         | 1404         | 1405         | 1406         | 1407         |
| 58          | 1408         | 1409           | 1410         | 1411         | 1412         | 1413         | 1414         | 1415         | 1416                 | 1417         | 1418         | 1419         | 1420         | 1421         | 1422         | 1423         |
| 59          | 1424         | 1425           | 1426         | 1427         | 1428         | 1429         | 1430         | 1431         | 1432                 | 1433         | 1434         | 1435         | 1436         | 1437         | 1438         | 1439         |
| 5A<br>5B    | 1440<br>1456 | 1441<br>1457   | 1442<br>1458 | 1443<br>1459 | 1444<br>1460 | 1445<br>1461 | 1446<br>1462 | 1447<br>1463 | 1448<br>1464         | 1449<br>1465 | 1450<br>1466 | 1451<br>1467 | 1452<br>1468 | 1453<br>1469 | 1454<br>1470 | 1455<br>1471 |
| 5C          | 1472         | 1473           | 1474         | 1475         | 1476         | 1477         | 1478         | 1479         | 1480                 | 1481         | 1482         | 1483         | 1484         | 1485         | 1486         | 1487         |
| 5D          | 1488         | 1489           | 1490         | 1491         | 1492         | 1493         | 1494         | 1495         | 1496                 | 1497         | 1498         | 1499         | 1500         | 1501         | 1502         | 1503         |
| 5E          | 1504         | 1505           | 1506         | 1507         | 1508         | 1509         | 1510         | 1511         | 1512                 | 1513         | 1514         | 1515         | 1516         | 1517         | 1518         | 1519         |
| 5F          | 1520         | 1521           | 1522         | 1523         | 1524         | 1525         | 1526         | 1527         | 1528                 | 1529         | 1530         | 1531         | 1532         | 1533         | 1534         | 1535         |
|             | 0            | 1              | 2            | 3            | 4            | 5            | 6            | 7            | 8                    | 9            | Α            | В            | С            | D            | E            | F            |
| 60          | 1536         | 1537           | 1538         | 1539         | 1540         | 1541         | 1542         | 1543         | 1544                 | 1545         | 1546         | 1547         | 1548         | 1549         | 1550         | 1551         |
| 61          | 1552         | 1553           | 1554         | 1555         | 1556         | 1557         | 1558         | 1559         | 1560                 | 1561         | 1562         | 1563         | 1564         | 1565         | 1566         | 1567         |
| 62<br>63    | 1568         | 1569           | 1570         | 1571         | 1572         | 1573         | 1574<br>1590 | 1575         | 1576<br>1592         | 1577<br>1593 | 1578<br>1594 | 1579<br>1595 | 1580<br>1596 | 1581<br>1597 | 1582<br>1598 | 1583<br>1599 |
| 64          | 1584<br>1600 | 1585<br>1601   | 1586<br>1602 | 1587<br>1603 | 1588<br>1604 | 1589<br>1605 | 1606         | 1591<br>1607 | 1608                 | 1609         | 1610         | 1611         | 1612         | 1613         | 1614         | 1615         |
| 65          | 1616         | 1617           | 1618         | 1619         | 1620         | 1621         | 1622         | 1623         | 1624                 | 1625         | 1626         | 1627         | 1628         | 1629         | 1630         | 1631         |
| 66          | 1632         | 1633           | 1634         | 1635         | 1636         | 1637         | 1638         | 1639         | 1640                 | 1641         | 1642         | 1643         | 1644         | 1645         | 1646         | 1647         |
| 67          | 1648         | 1649           | 1650         | 1651         | 1652         | 1653         | 1654         | 1655         | 1656                 | 1657         | 1658         | 1659         | 1660         | 1661         | 1662         | 1663         |
| 68<br>69    | 1664<br>1680 | 1665<br>1681   | 1666<br>1682 | 1667<br>1683 | 1668<br>1684 | 1669<br>1685 | 1670<br>1686 | 1671<br>1687 | 1672<br>1688         | 1673<br>1689 | 1674<br>1690 | 1675<br>1691 | 1676<br>1692 | 1677<br>1693 | 1678<br>1694 | 1679<br>1695 |
| 6A          | 1696         | 1697           | 1698         | 1699         | 1700         | 1701         | 1702         | 1703         | 1704                 | 1705         | 1706         | 1707         | 1708         | 1709         | 1710         | 1711         |
| 6B          | 1712         | 1713           | 1714         | 1715         | 1716         | 1717         | 1718         | 1719         | 1720                 | 1721         | 1722         | 1723         | 1724         | 1725         | 1726         | 1727         |
| 6C<br>6D    | 1728         | 1729           | 1730         | 1731         | 1732         | 1733         | 1734         | 1735         | 1736                 | 1737         | 1738         | 1739         | 1740         | 1741         | 1742         | 1743         |
| 6E          | 1744<br>1760 | 1745<br>1761   | 1746<br>1762 | 1747<br>1763 | 1748<br>1764 | 1749<br>1765 | 1750<br>1766 | 1751<br>1767 | 1752<br>1768         | 1753<br>1769 | 1754<br>1770 | 1755<br>1771 | 1756<br>1772 | 1757<br>1773 | 1758<br>1774 | 1759<br>1775 |
| 6F          | 1776         | 1777           | 1778         | 1779         | 1780         | 1781         | 1782         | 1783         | 1784                 | 1785         | 1786         | 1787         | 1788         | 1789         | 1790         | 1791         |
|             | 0            | 1              | 2            | 3            | 4            | 5            | 6            | 7            | 8                    | 9            | А            | В            | С            | D            | E            | F            |
| 70          | 1792         | 1793           | 1794         | 1795         | 1796         | 1797         | 1798         | 1799         | 1800                 | 1801         | 1802         | 1803         | 1804         | 1805         | 1806         | 1807         |
| 71          | 1808         | 1809           | 1810         | 1811         | 1812         | 1813         | 1814         | 1815         | 1816                 | 1817         | 1818         | 1819         | 1820         | 1821         | 1822         | 1823         |
| 72          | 1824         | 1825           | 1826         | 1827         | 1828         | 1829         | 1830         | 1831         | 1832                 | 1833         | 1834         | 1835         | 1836         | 1837         | 1838         | 1839         |
| 73<br>74    | 1840<br>1856 | 1841<br>1857   | 1842<br>1858 | 1843<br>1859 | 1844<br>1860 | 1845<br>1861 | 1846<br>1862 | 1847<br>1863 | 1848<br>1864         | 1849<br>1865 | 1850<br>1866 | 1851<br>1867 | 1852<br>1868 | 1853<br>1869 | 1854<br>1870 | 1855<br>1871 |
| 75          | 1872         | 1873           | 1874         | 1875         | 1876         | 1877         | 1878         | 1879         | 1880                 | 1881         | 1882         | 1883         | 1884         | 1885         | 1886         | 1887         |
| 76          | 1888         | 1889           | 1890         | 1891         | 1892         | 1893         | 1894         | 1895         | 1896                 | 1897         | 1898         | 1899         | 1900         | 1901         | 1902         | 1903         |
| 77          | 1904         | 1905           | 1906         | 1907         | 1908         | 1909         | 1910         | 1911         | 1912                 | 1913         | 1914         | 1915         | 1916         | 1917         | 1918         | 1919         |
| 78<br>79    | 1920<br>1936 | 1921<br>1937   | 1922<br>1938 | 1923<br>1939 | 1924<br>1940 | 1925<br>1941 | 1926<br>1942 | 1927<br>1943 | 1928<br>19 <b>44</b> | 1929<br>1945 | 1930<br>1946 | 1931         | 1932<br>1948 | 1933<br>1949 | 1934<br>1950 | 1935<br>1951 |
| 79<br>7A    | 1936         | 1937           | 1938         | 1955         | 1940         | 1941         | 1942         | 1943         | 1944                 | 1945         | 1946         | 1947<br>1963 | 1948         | 1949         | 1966         | 1967         |
| 7B          | 1968         | 1969           | 1970         | 1971         | 1972         | 1973         | 1974         | 1975         | 1976                 | 1977         | 1978         | 1979         | 1980         | 1981         | 1982         | 1983         |
| 7C          | 1984         | 1985           | 1986         | 1987         | 1988         | 1989         | 1990         | 1991         | 1992                 | 1993         | 1994         | 1995         | 1996         | 1997         | 1998         | 1999         |
| 7D          | 2000         | 2001           | 2002         | 2003         | 2004         | 2005         | 2006         | 2007         | 2008                 | 2009         | 2010         | 2011         | 2012         | 2013         | 2014         | 2015         |
| 7E<br>7F    | 2016<br>2032 | 2017<br>2033   | 2018<br>2034 | 2019<br>2035 | 2020<br>2036 | 2021<br>2037 | 2022<br>2038 | 2023<br>2039 | 2024<br>2040         | 2025<br>2041 | 2026<br>2042 | 2027<br>2043 | 2028<br>2044 | 2029<br>2045 | 2030<br>2046 | 2031<br>2047 |
| L' <u>'</u> | _ 2032       | 2000           | 2034         | 2030         | 2030         | 2037         | 2030         | 2038         | 2040                 | 2041         | 2042         | 2043         | 2044         | 2045         | 20-10        | 2047         |

Table C-2. Hexadecimal-Decimal Integer Conversion (Part 3 of 4)

|          |              |              |              |              | r            |              |              |              |              |              |              |              |              |              |              |              |
|----------|--------------|--------------|--------------|--------------|--------------|--------------|--------------|--------------|--------------|--------------|--------------|--------------|--------------|--------------|--------------|--------------|
|          | 0            | 1            | 2            | 3            | 4            | 5            | 6            | 7            | 8            | 9            | A            | В            | С            | D            | E            | F            |
| 80       | 2048         | 2049         | 2050         | 2051         | 2052         | 2053         | 2054         | 2055         | 2056         | 2057         | 2058         | 2059         | 2060         | 2061         | 2062         | 2063         |
| 81       | 2064         | 2065         | 2066         | 2067         | 2068         | 2069         | 2070         | 2071         | 2072         | 2073         | 2074         | 2075         | 2076         | 2077         | 2078         | 2079         |
| 82       | 2080         | 2081         | 2082         | 2083         | 2084         | 2085         | 2086         | 2087         | 2088         | 2089         | 2090         | 2091         | 2092         | 2093<br>2109 | 2094<br>2110 | 2095<br>2111 |
| 83<br>84 | 2096         | 2097<br>2113 | 2098<br>2114 | 2099<br>2115 | 2100<br>2116 | 2101<br>2117 | 2102<br>2118 | 2103<br>2119 | 2104<br>2120 | 2105<br>2121 | 2106<br>2122 | 2107<br>2123 | 2108<br>2124 | 2125         | 2116         | 2117         |
| 85       | 2128         | 2129         | 2130         | 2131         | 2132         | 2133         | 2134         | 2135         | 2136         | 2137         | 2138         | 2139         | 2140         | 2141         | 2142         | 2143         |
| 86       | 2144         | 2145         | 2146         | 2147         | 2148         | 2149         | 2150         | 2151         | 2152         | 2153         | 2154         | 2155         | 2156         | 2157         | 2158         | 2159         |
| 87       | 2160         | 2161         | 2162         | 2163         | 2164         | 2165         | 2166         | 2167         | 2168         | 2169         | 2170         | 2171         | 2172         | 2173         | 2174         | 2175         |
| 88<br>89 | 2176<br>2192 | 2177<br>2193 | 2178<br>2194 | 2179<br>2195 | 2180<br>2196 | 2181<br>2197 | 2182<br>2198 | 2183<br>2199 | 2184<br>2200 | 2185<br>2201 | 2186<br>2202 | 2187<br>2203 | 2188<br>2204 | 2189<br>2205 | 2190<br>2206 | 2191<br>2207 |
| 8A       | 2208         | 2209         | 2210         | 2211         | 2212         | 2213         | 2214         | 2215         | 2216         | 2217         | 2218         | 2219         | 2220         | 2221         | 2222         | 2223         |
| 88       | 2224         | 2225         | 2226         | 2227         | 2228         | 2229         | 2230         | 2231         | 2232         | 2233         | 2234         | 2235         | 2236         | 2237         | 2238         | 2239         |
| 8C       | 2240         | 2241         | 2242         | 2243         | 2244         | 2245         | 2246         | 2247         | 2248         | 2249         | 2250         | 2251         | 2252         | 2253         | 2254         | 2255         |
| 8D       | 2256         | 2257         | 2258         | 2259         | 2260<br>2276 | 2261<br>2277 | 2262<br>2278 | 2263<br>2279 | 2264<br>2280 | 2265<br>2281 | 2266<br>2282 | 2267<br>2283 | 2268<br>2284 | 2269<br>2285 | 2270<br>2286 | 2271<br>2287 |
| 8E<br>8F | 2272<br>2288 | 2273<br>2289 | 2274<br>2290 | 2275<br>2291 | 2270         | 2293         | 2276         | 2279         | 2296         | 2297         | 2298         | 2299         | 2300         | 2301         | 2302         | 2303         |
| ت        |              |              |              |              |              |              | _            |              |              |              |              |              |              |              |              |              |
|          | 0            | 1            | 2            | 3            | 4            | 5            | 6            | 7            | 8            | 9            | A            | В            | С            | D            | E            | F            |
| 90       | 2304         | 2305         | 2306         | 2307         | 2308         | 2309         | 2310         | 2311         | 2312         | 2313         | 2314         | 2315         | 2316         | 2317         | 2318         | 2319         |
| 91       | 2320         | 2321         | 2322         | 2323         | 2324         | 2325<br>2341 | 2326         | 2327<br>2343 | 2328<br>2344 | 2329<br>2345 | 2330<br>2346 | 2331<br>2347 | 2332<br>2348 | 2333<br>2349 | 2334<br>2350 | 2335<br>2351 |
| 92<br>93 | 2336<br>2352 | 2337<br>2353 | 2338<br>2354 | 2339<br>2355 | 2340<br>2356 | 2341         | 2342<br>2358 | 2343         | 2344         | 2345         | 2346         | 2347         | 2348         | 2349         | 2366         | 2367         |
| 94       | 2368         | 2369         | 2370         | 2371         | 2372         | 2373         | 2374         | 2375         | 2376         | 2377         | 2378         | 2379         | 2380         | 2381         | 2382         | 2383         |
| 95       | 2384         | 2385         | 2386         | 2387         | 2388         | 2389         | 2390         | 2391         | 2392         | 2393         | 2394         | 2395         | 2396         | 2397         | 2398         | 2399         |
| 96       | 2400         | 2401         | 2402         | 2403         | 2404         | 2405         | 2406         | 2407         | 2408         | 2409         | 2410         | 2411         | 2412         | 2413         | 2414         | 2415         |
| 97       | 2416         | 2417<br>2433 | 2418<br>2434 | 2419<br>2435 | 2420<br>2436 | 2421<br>2437 | 2422<br>2438 | 2423<br>2439 | 2424<br>2440 | 2425<br>2441 | 2426<br>2442 | 2427<br>2443 | 2428<br>2444 | 2429<br>2445 | 2430<br>2446 | 2431<br>2447 |
| 99       | 2432<br>2448 | 2433         | 2454         | 2455         | 2452         | 2453         | 2456         | 2455         | 2456         | 2457         | 2458         | 2459         | 2460         | 2461         | 2462         | 2463         |
| 9A       | 2464         | 2465         | 2466         | 2467         | 2468         | 2469         | 2470         | 2471         | 2472         | 2473         | 2474         | 2475         | 2476         | 2477         | 2478         | 2479         |
| 9B       | 2480         | 2481         | 2482         | 2483         | 2484         | 2485         | 2486         | 2487         | 2488         | 2489         | 2490         | 2491         | 2492         | 2493         | 2494         | 2495         |
| 9C       | 2496         | 2497         | 2498         | 2499         | 2500         | 2501         | 2502         | 2503         | 2504         | 2505         | 2506         | 2507         | 2508         | 2509         | 2510         | 2511         |
| 9D<br>9E | 2512<br>2528 | 2513<br>2529 | 2514<br>2530 | 2515<br>2531 | 2516<br>2532 | 2517<br>2533 | 2518<br>2534 | 2519<br>2535 | 2520<br>2536 | 2521<br>2537 | 2522<br>2538 | 2523<br>2539 | 2524<br>2540 | 2525<br>2541 | 2526<br>2542 | 2527<br>2543 |
| 9F       | 2544         | 2545         | 2546         | 2547         | 2548         | 2549         | 2550         | 2551         | 2552         | 2553         | 2554         | 2555         | 2556         | 2557         | 2558         | 2559         |
| <u> </u> | 0            | 1            | 2            | 3            | 4            | 5            | 6            | 7            | 8            | 9            | Α            | В            | С            | D            | E            | F            |
|          |              | l            | <del> </del> | -            |              |              | _            |              |              |              |              |              |              |              |              | -            |
| A0<br>A1 | 2560<br>2576 | 2561<br>2577 | 2562<br>2578 | 2563<br>2579 | 2564<br>2580 | 2565<br>2581 | 2566<br>2582 | 2567<br>2583 | 2568<br>2584 | 2569<br>2585 | 2570<br>2586 | 2571<br>2587 | 2572<br>2588 | 2573<br>2589 | 2574<br>2590 | 2575<br>2591 |
| A2       | 2592         | 2593         | 2594         | 2595         | 2596         | 2597         | 2598         | 2599         | 2600         | 2601         | 2602         | 2603         | 2604         | 2605         | 2606         | 2607         |
| A3       | 2608         | 2609         | 2610         | 2611         | 2612         | 2613         | 2614         | 2615         | 2616         | 2617         | 2618         | 2619         | 2620         | 2621         | 2622         | 2623         |
| A4       | 2624         | 2625         | 2626         | 2627         | 2628         | 2629         | 2630         | 2631         | 2632         | 2633         | 2634         | 2635         | 2636         | 2637         | 2638         | 2639         |
| A5<br>A6 | 2640<br>2656 | 2641<br>2657 | 2642<br>2658 | 2643<br>2659 | 2644<br>2660 | 2645<br>2661 | 2646<br>2662 | 2647<br>2663 | 2648<br>2664 | 2649<br>2665 | 2650<br>2666 | 2651<br>2667 | 2652<br>2668 | 2653<br>2669 | 2654<br>2670 | 2655<br>2671 |
| A7       | 2672         | 2673         | 2674         | 2675         | 2676         | 2677         | 2678         | 2679         | 2680         | 2681         | 2682         | 2683         | 2684         | 2685         | 2686         | 2687         |
| A8       | 2688         | 2689         | 2690         | 2691         | 2692         | 2693         | 2694         | 2695         | 2696         | 2697         | 2698         | 2699         | 2700         | 2701         | 2702         | 2703         |
| A9       | 2704         | 2705         | 2706         | 2707         | 2708         | 2709         | 2710         | 2711         | 2712         | 2713         | 2714         | 2715         | 2716         | 2717         | 2718         | 2719         |
| AA       | 2720         | 2721         | 2722         | 2723         | 2724         | 2725         | 2726         | 2727         | 2728         | 2729         | 2730         | 2731         | 2732         | 2733         | 2734         | 2735         |
| AB       | 2736<br>2752 | 2737<br>2753 | 2738<br>2754 | 2739<br>2755 | 2740<br>2756 | 2741<br>2757 | 2742<br>2758 | 2743<br>2759 | 2744<br>2760 | 2745<br>2761 | 2746<br>2762 | 2747<br>2763 | 2748<br>2764 | 2749<br>2765 | 2750<br>2766 | 2751<br>2767 |
| AD       | 1            | 2769         | 2770         | 2771         | 2772         | 2773         | 2774         | 2775         | 2776         | 2777         | 2778         | 2779         | 2780         | 2781         | 2782         | 2783         |
| AE       | 2784         | 2785         | 2786         | 2787         | 2788         | 2789         | 2790         | 2791         | 2792         | 2793         | 2794         | 2795         | 2796         | 2797         | 2798         | 2799         |
| AF       | 2800         | 2801         | 2802         | 2803         | 2804         | 2805         | 2806         | 2807         | 2808         | 2809         | 2810         | 2811         | 2812         | 2813         | 2814         | 2815         |
|          | 0            | 1            | 2            | 3            | 4            | 5            | 6            | 7            | 8            | 9            | Α            | В            | С            | D            | E            | F            |
| ВО       | 2816         | 2817         | 2818         | 2819         | 2820         | 2821         | 2822         | 2823         | 2824         | 2825         | 2826         | 2827         | 2828         | 2829         | 2830         | 2831         |
| B1       | 2832         | 2833         | 2834         | 2835         | 2836         | 2837         | 2838         | 2839         | 2840         | 2841         | 2842         | 2843         | 2844         | 2845         | 2846         | 2847         |
| B2       | 2848         | 2849         | 2850         | 2851         | 2852         | 2853         | 2854         | 2855         | 2856         | 2857         | 2858         | 2859         | 2860         | 2861         | 2862         | 2863         |
| B3<br>B4 | 2864<br>2880 | 2865<br>2881 | 2866<br>2882 | 2867<br>2883 | 2868<br>2884 | 2869<br>2885 | 2870<br>2886 | 2871<br>2887 | 2872<br>2888 | 2873<br>2889 | 2874<br>2890 | 2875<br>2891 | 2876<br>2892 | 2877<br>2893 | 2878<br>2894 | 2879<br>2895 |
| B5       | 2896         | 2897         | 2898         | 2899         | 2900         | 2901         | 2902         | 2903         | 2904         | 2905         | 2906         | 2907         | 2908         | 2909         | 2910         | 2911         |
| В6       | 2912         | 2913         | 2914         | 2915         | 2916         | 2917         | 2918         | 2919         | 2920         | 2921         | 2922         | 2923         | 2924         | 2925         | 2926         | 2927         |
| B7       | 2928         | 2929         | 2930         | 2931         | 2932         | 2933         | 2934         | 2935         | 2936         | 2937         | 2938         | 2939         | 2940         | 2941         | 2942         | 2943         |
| B8<br>B9 | 2944<br>2960 | 2945<br>2961 | 2946<br>2962 | 2947<br>2963 | 2948<br>2964 | 2949<br>2965 | 2950<br>2966 | 2951<br>2967 | 2952<br>2968 | 2953<br>2969 | 2954<br>2970 | 2955<br>2971 | 2956<br>2972 | 2957<br>2973 | 2958<br>2974 | 2959<br>2975 |
| BA<br>BA | 2960         | 2961         | 2962         | 2963         | 2964<br>2980 | 2981         | 2982         | 2983         | 2984         | 2985         | 2986         | 2987         | 2988         | 2989         | 2990         | 2991         |
| ВВ       | 2992         | 2993         | 2994         | 2995         | 2996         | 2997         | 2998         | 2999         | 3000         | 3001         | 3002         | 3003         | 3004         | 3005         | 3006         | 3007         |
| ВС       | 3008         | 3009         | 3010         | 3011         | 3012         | 3013         | 3014         | 3015         | 3016         | 3017         | 3018         | 3019         | 3020         | 3021         | 3022         | 3023         |
| BD       | 3024         | 3025         | 3026         | 3027         | 3028         | 3029         | 3030         | 3031         | 3032         | 3033         | 3034         | 3035         | 3036         | 3037         | 3038         | 3039         |
| BE<br>BF | 3040<br>3056 | 3041<br>3057 | 3042<br>3058 | 3043<br>3059 | 3044<br>3060 | 3045<br>3061 | 3046<br>3062 | 3047<br>3063 | 3048<br>3064 | 3049<br>3065 | 3050<br>3066 | 3051<br>3067 | 3052<br>3068 | 3053<br>3069 | 3054<br>3070 | 3055<br>3071 |
| I Br     | 1 2020       | 1 305/       | I วกอด       | บบอล         | 3000         | 3001         | 3002         | 3003         | 3004         | 3000         | 3000         | 3007         | 3000         | 5505         | 3070         | 5571         |

Table C-2. Hexadecimal-Decimal Integer Conversion (Part 4 of 4)

| 1          |                      |                       | r                     |              |              |              |              |              |              |              |              |                       |              |              |              |              |
|------------|----------------------|-----------------------|-----------------------|--------------|--------------|--------------|--------------|--------------|--------------|--------------|--------------|-----------------------|--------------|--------------|--------------|--------------|
|            | 0                    | 1                     | 2                     | 3            | 4            | 5            | 6            | 7            | 8            | 9            | Α            | В                     | С            | D            | E            | F            |
| co         | 3072                 | 3073                  | 3074                  | 3075         | 3076         | 3077         | 3078         | 3079         | 3080         | 3081         | 3082         | 3083                  | 3084         | 3085         | 3086         | 3087         |
| C1<br>C2   | 3088<br>3104         | 3089<br>3105          | 3090<br>3106          | 3091<br>3107 | 3092<br>3108 | 3093<br>3109 | 3094<br>3110 | 3095<br>3111 | 3096<br>3112 | 3097<br>3113 | 3098<br>3114 | 3099<br>3115          | 3100<br>3116 | 3101<br>3117 | 3102<br>3118 | 3103<br>3119 |
| C3         | 3120                 | 3103                  | 3122                  | 3123         | 3124         | 3125         | 3126         | 3127         | 3128         | 3129         | 3130         | 3131                  | 3132         | 3133         | 3134         | 3135         |
| C4         | 3136                 | 3137                  | 3138                  | 3139         | 3140         | 3141         | 3142         | 3143         | 3144         | 3145         | 3146         | 3147                  | 3148         | 3149         | 3150         | 3151         |
| C5<br>C6   | 3152<br>3168         | 3153<br>3169          | 3154<br>3170          | 3155<br>3171 | 3156<br>3172 | 3157<br>3173 | 3158<br>3174 | 3159<br>3175 | 3160<br>3176 | 3161<br>3177 | 3162<br>3178 | 3163<br>3179          | 3164<br>3180 | 3165<br>3181 | 3166<br>3182 | 3167<br>3183 |
| C7         | 3184                 | 3185                  | 3186                  | 3187         | 3188         | 3189         | 3190         | 3191         | 3192         | 3193         | 3194         | 3195                  | 3196         | 3197         | 3198         | 3199         |
| C8         | 3200                 | 3201                  | 3202                  | 3203         | 3204         | 3205         | 3206         | 3207         | 3208         | 3209         | 3210         | 3211                  | 3212         | 3213         | 3214         | 3215         |
| C9         | 3216                 | 3217                  | 3218                  | 3219         | 3220         | 3221         | 3222         | 3223<br>3239 | 3224<br>3240 | 3225<br>3241 | 3226         | 3227<br>3243          | 3228<br>3244 | 3229<br>3245 | 3230<br>3246 | 3231<br>3247 |
| CA         | 3232<br>3248         | 3233<br>3249          | 3234<br>3250          | 3235<br>3251 | 3236<br>3252 | 3237<br>3253 | 3238<br>3254 | 3255         | 3256         | 3257         | 3242<br>3258 | 3259                  | 3260         | 3261         | 3262         | 3263         |
| cc         | 3264                 | 3265                  | 3266                  | 3267         | 3268         | 3269         | 3270         | 3271         | 3272         | 3273         | 3274         | 3275                  | 3276         | 3277         | 3278         | 3279         |
| CD         | 3280                 | 3281                  | 3282                  | 3283         | 3284         | 3285         | 3286         | 3287         | 3288         | 3289         | 3290         | 3291                  | 3292         | 3293         | 3294         | 3295         |
| CE CF      | 3296<br>3312         | 3297<br>3313          | 3298<br>3314          | 3299<br>3315 | 3300<br>3316 | 3301<br>3317 | 3302<br>3318 | 3303<br>3319 | 3304<br>3320 | 3305<br>3321 | 3306<br>3322 | 3307<br>3323          | 3308<br>3324 | 3309<br>3325 | 3310<br>3326 | 3311<br>3327 |
|            |                      |                       |                       |              |              |              |              |              |              |              |              |                       |              |              |              |              |
|            | 0                    | 1                     | 2                     | 3            | 4            | 5            | 6            | 7            | 8            | 9            | Α .          | В                     | С            | D            | E            | F            |
| D0         | 3328                 | 3329                  | 3330                  | 3331         | 3332         | 3333         | 3334         | 3335         | 3336         | 3337         | 3338         | 3339                  | 3340         | 3341         | 3342         | 3343         |
| D1<br>D2   | 3344<br>3360         | 3345<br>3361          | 3346<br>3362          | 3347<br>3363 | 3348<br>3364 | 3349<br>3365 | 3350<br>3366 | 3351<br>3367 | 3352<br>3368 | 3353<br>3369 | 3354<br>3370 | 3355<br>3371          | 3356<br>3372 | 3357<br>3373 | 3358<br>3374 | 3359<br>3375 |
| D3         | 3360                 | 3361                  | 3362                  | 3379         | 3380         | 3381         | 3382         | 3383         | 3384         | 3385         | 3386         | 3387                  | 3388         | 3389         | 3390         | 3391         |
| D4         | 3392                 | 3393                  | 3394                  | 3395         | 3396         | 3397         | 3398         | 3399         | 3400         | 3401         | 3402         | 3403                  | 3404         | 3405         | 3406         | 3407         |
| D5         | 3408                 | 3409                  | 3410                  | 3411         | 3412         | 3413         | 3414         | 3415         | 3416         | 3417         | 3418         | 3419                  | 3420         | 3421         | 3422         | 3423         |
| D6         | 3424<br>3440         | 3425<br>3441          | 3426<br>3442          | 3427<br>3443 | 3428<br>3444 | 3429<br>3445 | 3430<br>3446 | 3431<br>3447 | 3432<br>3448 | 3433<br>3449 | 3434<br>3450 | 3435<br>3451          | 3436<br>3452 | 3437<br>3453 | 3438<br>3454 | 3439<br>3455 |
| D8         | 3456                 | 3457                  | 3458                  | 3459         | 3460         | 3461         | 3462         | 3463         | 3464         | 3465         | 3466         | 3467                  | 3468         | 3469         | 3470         | 3471         |
| D9         | 3472                 | 3473                  | 3474                  | 3475         | 3476         | 3477         | 3478         | 3479         | 3480         | 3481         | 3482         | 3483                  | 3484         | 3485         | 3486         | 3487         |
| DA         | 3488                 | 3489                  | 3490                  | 3491         | 3492         | 3493         | 3494         | 3495         | 3496         | 3497         | 3498         | 3499                  | 3500         | 3501         | 3502         | 3503<br>3519 |
| DB         | 3504<br>3520         | 3505<br>3521          | 3506<br>3522          | 3507<br>3523 | 3508<br>3524 | 3509<br>3525 | 3510<br>3526 | 3511<br>3527 | 3512<br>3528 | 3513<br>3529 | 3514<br>3530 | 3515<br>3531          | 3516<br>3532 | 3517<br>3533 | 3518<br>3534 | 3535         |
| DD         | 3536                 | 3537                  | 3538                  | 3539         | 3540         | 3541         | 3542         | 3543         | 3544         | 3545         | 3546         | 3547                  | 3548         | 3549         | 3550         | 3551         |
| DE         | 3552                 | 3553                  | 3554                  | 3555         | 3556         | 3557         | 3558         | 3559         | 3560         | 3561         | 3562         | 3563                  | 3564         | 3565         | 3566         | 3567         |
| DF         | 3568                 | 3569                  | 3570                  | 3571         | 3572         | 3573         | 3574         | 3575         | 3576         | 3577         | 3578         | 3579                  | 3580         | 3581         | 3582         | 3583         |
|            | 0                    | 1                     | 2                     | 3            | 4            | 5            | 6            | 7            | 8            | 9            | Α            | В                     | С            | D            | E            | F            |
| ΕO         | 3584                 | 3585                  | 3586                  | 3587         | 3588         | 3589         | 3590         | 3591         | 3592         | 3593         | 3594         | 3595                  | 3596         | 3597         | 3598         | 3599         |
| E1         | 3600                 | 3601                  | 3602                  | 3603         | 3604         | 3605         | 3606         | 3607         | 3608         | 3609         | 3610         | 3611                  | 3612         | 3613         | 3614         | 3615         |
| E2         | 3616<br>3632         | 3617<br>3633          | 3618                  | 3619<br>3635 | 3620<br>3636 | 3621<br>3637 | 3622<br>3638 | 3623<br>3639 | 3624<br>3640 | 3625<br>3641 | 3626<br>3642 | 3627<br>3643          | 3628<br>3644 | 3629<br>3645 | 3630<br>3646 | 3631<br>3647 |
| E4         | <i>3</i> 63∠<br>3648 | 3649                  | 3634<br>3650          | 3651         | 3652         | 3653         | 3654         | 3655         | 3656         | 3657         | 3658         | 3659                  | 3660         | 3661         | 3662         | 3663         |
| E5         | 3664                 | 3665                  | 3666                  | 3667         | 3668         | 3669         | 3670         | 3671         | 3672         | 3673         | 3674         | 3675                  | 3676         | 3677         | 3678         | 3679         |
| E6         | 3680                 | 3681                  | 3682                  | 3683         | 3684         | 3685         | 3686         | 3687         | 3688         | 3689         | 3690         | 3691                  | 3692         | 3693         | 3694         | 3695         |
| E7         | 3696<br>3712         | 3697<br>3713          | 3698<br>3714          | 3699<br>3715 | 3700<br>3716 | 3701<br>3717 | 3702<br>3718 | 3703<br>3719 | 3704<br>3720 | 3705<br>3721 | 3706<br>3722 | 3707<br>3 <b>72</b> 3 | 3708<br>3724 | 3709<br>3725 | 3710<br>3726 | 3711<br>3727 |
| E9         | 3712                 | 3729                  | 3730                  | 3731         | 3732         | 3733         | 3734         | 3735         | 3736         | 3737         | 3738         | 3739                  | 3740         | 3741         | 3742         | 3743         |
| EA         | 3744                 | 3745                  | 3746                  | 3747         | 3748         | 3749         | 3750         | 3751         | 3752         | 3753         | 3754         | 3755                  | 3756         | 3757         | 3758         | 3759         |
| EB         | 3760                 | 3761                  | 3762                  | 3763         | 3764         | 3765         | 3766         | 3767         | 3768         | 3769         | 3770         | 3771                  | 3772         | 3773         | 3774         | 3775<br>3791 |
| EC         | 3776<br>3792         | 3777<br>3 <b>7</b> 93 | 3778<br>3 <b>7</b> 94 | 3779<br>3795 | 3780<br>3796 | 3781<br>3797 | 3782<br>3798 | 3783<br>3799 | 3784<br>3800 | 3785<br>3801 | 3786<br>3802 | 3787<br>3803          | 3788<br>3804 | 3789<br>3805 | 3790<br>3806 | 3/91         |
| EE         | 3808                 | 3809                  | 3810                  | 3811         | 3812         | 3813         | 3814         | 3815         | 3816         | 3817         | 3818         | 3819                  | 3820         | 3821         | 3822         | 3823         |
| EF         | 3824                 | 3825                  | 3826                  | 3827         | 3828         | 3829         | 3830         | 3831         | 3832         | 3833         | 3834         | 3835                  | 3836         | 3837         | 3838         | 3839         |
|            | 0                    | 1                     | 2                     | 3            | 4            | 5            | 6            | 7            | 8            | 9            | А            | В                     | С            | D            | E            | F            |
| F0         | 3840                 | 3841                  | 3842                  | 3843         | 3844         | 3845         | 3846         | 3847         | 3848         | 3849         | 3850         | 3851                  | 3852         | 3853         | 3854         | 3855         |
| F1         | 3856                 | 3857                  | 3858                  | 3859         | 3860         | 3861         | 3862         | 3863         | 3864         | 3865         | 3866         | 3867                  | 3868         | 3869         | 3870         | 3871         |
| F2<br>F3   | 3872<br>3888         | 3873<br>3889          | 3874<br>3890          | 3875<br>3891 | 3876<br>3892 | 3877<br>3893 | 3878<br>3894 | 3879<br>3895 | 3880<br>3896 | 3881<br>3897 | 3882<br>3898 | 3883<br>3899          | 3884<br>3900 | 3885<br>3901 | 3886<br>3902 | 3887<br>3903 |
| F4         | 3904                 | 3905                  | 3906                  | 3907         | 3908         | 3909         | 3910         | 3911         | 3912         | 3913         | 3914         | 3915                  | 3916         | 3917         | 3918         | 3919         |
| F5         | 3920                 | 3921                  | 3922                  | 3923         | 3924         | 3925         | 3926         | 3927         | 3928         | 3929         | 3930         | 3931                  | 3932         | 3933         | 3934         | 3935         |
| F6         | 3936                 | 3937                  | 3938                  | 3939         | 3940         | 3941         | 3942         | 3943         | 3944         | 3945         | 3946         | 3947                  | 3948         | 3949         | 3950         | 3951         |
| F7<br>  F8 | 3952<br>3968         | 3953<br>3969          | 3954<br>3970          | 3955<br>3971 | 3956<br>3972 | 3957<br>3973 | 3958<br>3974 | 3959<br>3975 | 3960<br>3976 | 3961<br>3977 | 3962<br>3978 | 3963<br>3979          | 3964<br>3980 | 3965<br>3981 | 3966<br>3982 | 3967<br>3983 |
| F9         | 3984                 | 3985                  | 3986                  | 3987         | 3988         | 3989         | 3990         | 3991         | 3992         | 3993         | 3994         | 3995                  | 3996         | 3997         | 3998         | 3999         |
| FA         | 4000                 | 4001                  | 4002                  | 4003         | 4004         | 4005         | 4006         | 4007         | 4008         | 4009         | 4010         | 4011                  | 4012         | 4013         | 4014         | 4015         |
| FB         | 4016                 | 4017                  | 4018                  | 4019         | 4020         | 4021         | 4022         | 4023         | 4024         | 4025         | 4026         | 4027                  | 4028         | 4029         | 4030         | 4031<br>4047 |
| FC<br>FD   | 4032<br>4048         | 4033<br>4049          | 4034<br>4050          | 4035<br>4051 | 4036<br>4052 | 4037<br>4053 | 4038<br>4054 | 4039<br>4055 | 4040<br>4056 | 4041<br>4057 | 4042<br>4058 | 4043<br>4059          | 4044<br>4060 | 4045<br>4061 | 4046<br>4062 | 4047         |
| FE         | 4048                 | 4065                  | 4066                  | 4067         | 4068         | 4069         | 4070         | 4071         | 4072         | 4073         | 4074         | 4075                  | 4076         | 4077         | 4078         | 4079         |
| FF         | 4080                 | 4081                  | 4082                  | 4083         | 4084         | 4085         | 4086         | 4087         | 4088         | 4089         | 4090         | 4091                  | 4092         | 4093         | 4094         | 4095         |
|            |                      |                       | <u> </u>              |              |              |              | L            | L            |              |              |              |                       | L            |              |              |              |

Table C-3. Hexadecimal-Decimal Fraction Conversion

| Firs | t Digit | Se   | cond Digit |      |      | Third        | Digit |      |       | Fourth | Digit   |      |
|------|---------|------|------------|------|------|--------------|-------|------|-------|--------|---------|------|
| Hex. | Decimal | Hex. | Decir      | nal  | Hex. | Hex. Decimal |       |      |       |        | Decimal |      |
| .0   | .0000   | .00  | .0000      | 0000 | .000 | .0000        | 0000  | 0000 | .0000 | .0000  | 0000    | 0000 |
| .1   | .0625   | .01  | .0039      | 0625 | .001 | .0002        | 4414  | 0625 | .0001 | .0000  | 1525    | 8789 |
| .2   | .1250   | .02  | .0078      | 1250 | .002 | .0004        | 8828  | 1250 | .0002 | .0000  | 3051    | 7578 |
| .3   | .1875   | .03  | .0117      | 1875 | .003 | .0007        | 3242  | 1875 | .0003 | .0000  | 4577    | 6367 |
| .4   | .2500   | .04  | .0156      | 2500 | .004 | .0009        | 7656  | 2500 | .0004 | .0000  | 6103    | 5156 |
| .5   | .3125   | .05  | .0195      | 3125 | .005 | .0012        | 2070  | 3125 | ,0005 | .0000  | 7629    | 3945 |
| .6   | .3750   | .06  | .0234      | 3750 | .006 | .0014        | 6486  | 3750 | .0006 | .0000  | 9155    | 2734 |
| .7   | .4375   | .07  | .0273      | 4375 | .007 | .0017        | 0898  | 4375 | .0007 | .0001  | 0681    | 1523 |
| .8   | .5000   | .08  | .0312      | 5000 | .008 | .0019        | 5312  | 5000 | .0008 | .0001  | 2207    | 0313 |
| .9   | .5625   | .09  | .0351      | 5625 | .009 | .0021        | 9726  | 5625 | .0009 | .0001  | 3732    | 9102 |
| .A   | .6250   | .0A  | .0390      | 6250 | .00A | .0024        | 4140  | 6250 | .000A | .0001  | 5258    | 7891 |
| .B   | .6875   | .0B  | .0429      | 6875 | .00B | .0026        | 8554  | 6875 | .000В | .0001  | 6784    | 6680 |
| .C   | .7500   | .0C  | .0468      | 7500 | .00C | .0029        | 2968  | 7500 | .000C | .0001  | 8310    | 5469 |
| .D   | .8125   | .0D  | .0507      | 8125 | .00D | .0031        | 7382  | 8125 | .000D | .0001  | 9836    | 4258 |
| .E   | .8750   | .0E  | .0546      | 8750 | .00E | .0034        | 1796  | 8750 | .000E | .0002  | 1362    | 3047 |
| .F   | .9375   | .0F  | .0585      | 9375 | .00F | .0036        | 6210  | 9375 | .000F | .0002  | 2888    | 1836 |

To convert a 4-digit (2-byte) hexadecimal fraction to a decimal fraction, add the values shown in the above table for each of the hexadecimal digits to be converted as illustrated below. The hexadecimal fraction .B5A1 equals the approximate decimal fraction .70948791 from the above table.

| .В    | from the table equals | .6875         |
|-------|-----------------------|---------------|
| .05   | from the table equals | .01953125     |
| .00A  | from the table equals | .002441406250 |
| .0001 | from the table equals | .000015258789 |
| .B5A1 | equals the sum        | .709487915039 |

NOTE:

All values listed are approximate values.

Table C-4. Hexadecimal Addition and Subtraction Table

| 1    |     |     |    |     |     |     |     |      |     |     |     |     |     |     |    |    |    |    |    |      |    | _  |    |    |    |    |    |      |    |     |    | 1  |
|------|-----|-----|----|-----|-----|-----|-----|------|-----|-----|-----|-----|-----|-----|----|----|----|----|----|------|----|----|----|----|----|----|----|------|----|-----|----|----|
|      | 01  | 02  | 03 | 04  | 05  | 06  | 07  | 08   | 09  | 0A  | OB  | 0C  | 0D  | 0E  | 0F | 10 | 11 | 12 | 13 | 14   | 15 | 16 | 17 | 18 | 19 | 1A | 1B | 1C   | 1D | 1E  | 1F |    |
| 01   | 02  | 03  | 04 | 05  | 06  | 07  | 08  | 09   | 0A  | 0B  | OC. | 0D  | 0E  | 0F  | 10 | 11 | 12 | 13 | 14 | 15   | 16 | 17 | 18 | 19 | 1A | 1B | 1C | 1D   | 1E | 1F  | 20 | 01 |
| 02   | 03  | 04  | 05 | 06  | 07  | 08  | 09  | 0A   | OB  | OC. | OD  | 0E  | OF  | 10  | 11 | 12 | 13 | 14 | 15 | 16   | 17 | 18 | 19 | 1A | 18 | 1C | 1D | 1E   | 1F | 20  | 21 | 02 |
| 03   | 04  | 05  | 06 | 07  | 08  | 09  | 0A  | ОВ   | OC. | 0D  | OE  | OF  | 10  | 11  | 12 | 13 | 14 | 15 | 16 | 17   | 18 | 19 | 1A | 1B | 1C | 1D | 1E | 1F   | 20 | 21  | 22 | 03 |
| 04   | 05  | 06  | 07 | 08  | 09  | 0A  | 0B  | oc   | 0D  | OE. | 0F  | 10  | 11  | 12  | 13 | 14 | 15 | 16 | 17 | 18   | 19 | 1A | 18 | 1C | 1D | 1E | 1F | 20   | 21 | 22  | 23 | 04 |
| 05   | 06  | 07  | 80 | 09  | 0A  | OB  | OC. | OD   | 0E  | 0F  | 10  | 11  | 12  | 13  | 14 | 15 | 16 | 17 | 18 | 19   | 1A | 1B | 1C | 1D | 1E | 1F | 20 | 21.5 | 22 | 23  | 24 | 05 |
| 06   | 07  | 08  | 09 | _0A | ОВ  | oc_ | OD. | OE   | OF  | 10_ | 11  | 12_ | 13  | 14  | 15 | 16 | 17 | 18 | 19 | 1A   | 1B | 1C | 1D | 1E | 1F | 20 | 21 | 22   | 23 | 24  | 25 | 06 |
| 07   | 08  | 09  | 0A | OB  | OC. | OD. | 0E  | OF   | 10  | 11  | 12  | 13  | 14  | 15  | 16 | 17 | 18 | 19 | 1A | 1B   | 1C | 1D | 1E | 1F | 20 | 21 | 22 | 23   | 24 | 25  | 26 | 07 |
| - 08 | 09  | 0A  | ов | OC. | 0D  | 0E  | 0F  | 10   | 11  | 12  | 13  | 14  | 15  | 16  | 17 | 18 | 19 | 1A | 1B | 1C   | 1D | 1E | 1F | 20 | 21 | 22 | 23 | 24   | 25 | 26  | 27 | 08 |
| 09   | 0A  | OB  | oc | 0D  | 0E  | OF  | 10  | 11   | 12  | 13  | 14  | 15  | 16  | 17  | 18 | 19 | 1A | 1B | 1C | 1 D  | 1E | 1F | 20 | 21 | 22 | 23 | 24 | 25   | 26 | 27  | 28 | 09 |
| 0A   | OB  | OC. | 0D | 0E  | 0F  | 10  | 11  | 12   | 13  | 14_ | 15  | 16  | 17  | 18  | 19 | 1A | 1B | 1C | 1D | 1E   | 1F | 20 | 21 | 22 | 23 | 24 | 25 | 26   | 27 | 28_ | 29 | 0A |
| 0B   | oc  | 0D  | 0E | OF  | 10  | 11  | 12  | 13   | 14  | 15  | 16  | 17  | 18  | 19  | 1A | 18 | 1C | 1D | 1E | 1F   | 20 | 21 | 22 | 23 | 24 | 25 | 26 | 27   | 28 | 29  | 2A | OB |
| oc   | OD  | 0E  | OF | 10  | 11  | 12  | 13  | 14   | 15  | 16  | 17  | 18  | 19  | 1A  | 1B | 1C | 1D | 1E | 1F | 20   | 21 | 22 | 23 | 24 | 25 | 26 | 27 | 28   | 29 | 2A  | 2B | OC |
| 0D   | 0E  | OF  | 10 | 11  | 12  | 13  | 14  | 15   | 16  | 17  | 18  | 19  | 1A  | 1B  | 1C | 1D | 1E | 1F | 20 | 21   | 22 | 23 | 24 | 25 | 26 | 27 | 28 | 29   | 2A | 2B  | 2C | OD |
| 0E   | OF  | 10  | 11 | 12  | 13  | 14  | 15  | 16   | 17  | 18  | 19  | 1A  | 1B  | 1C  | 1D | 1E | 1F | 20 | 21 | 22   | 23 | 24 | 25 | 26 | 27 | 28 | 29 | 2A   | 2B | 2C  | 2D | 0E |
| 0F   | 10  | 11  | 12 | 13  | 14  | 15  | 16  | 17_  | 18  | 19  | 1A  | _1B | 1C  | 1D  | 1E | 1F | 20 | 21 | 22 | 23   | 24 | 25 | 26 | 27 | 28 | 29 | 2A | 2B   | 2C | 2D  | 2E | 0F |
| 10   | 11  | 12  | 13 | 14  | 15  | 16  | 17  | 18   | 19  | 1A  | 1B  | 1C  | 1D  | 1 E | 1F | 20 | 21 | 22 | 23 | 24   | 25 | 26 | 27 | 28 | 29 | 2A | 2B | 2C   | 2D | 2E  | 2F | 10 |
| 11   | 12  | 13  | 14 | 15  | 16  | 17  | 18  | 19   | 1A  | 1B  | 1C  | 1D  | 1 E | 1F  | 20 | 21 | 22 | 23 | 24 | 25   | 26 | 27 | 28 | 29 | 2A | 2B | 2C | 2D   | 2E | 2F  | 30 | 11 |
| 12   | 13  | 14  | 15 | 16  | 17  | 18  | 19  | 1A   | 18  | 1C  | 1D  | 1E  | 1F  | 20  | 21 | 22 | 23 | 24 | 25 | 26   | 27 | 28 | 29 | 2A | 2B | 2C | 2D | 2E   | 2F | 30  | 31 | 12 |
| 13   | 14  | 15  | 16 | 17  | 18  | 19  | 1A  | 1B   | 1C  | 1D  | 1E  | 1F  | 20  | 21  | 22 | 23 | 24 | 25 | 26 | 27   | 28 | 29 | 2A | 2B | 2C | 2D | 2E | 2F   | 30 | 31  | 32 | 13 |
| 14   | 15  | 16  | 17 | 18  | 19  | 1A  | 1B  | 1C   | 1D  | 1E  | 1F  | 20  | 21  | 22  | 23 | 24 | 25 | 26 | 27 | 28   | 29 | 2A | 2B | 2C | 2D | 2E | 2F | 30   | 31 | 32  | 33 | 14 |
| 15   | 16  | 17  | 18 | 19  | 1A  | 1B  | 1C  | _1D_ | 1E  | 1F  | 20  | 21  | 22  | 23  | 24 | 25 | 26 | 27 | 28 | _29_ | 2A | 2B | 2C | 2D | 2€ | 2F | 30 | 31   | 32 | 33_ | 34 | 15 |
| 16   | 17  | 18  | 19 | 1A  | 18  | 1C  | 1D  | 1E   | 1F  | 20  | 21  | 22  | 23  | 24  | 25 | 26 | 27 | 28 | 29 | 2A   | 2B | 2C | 2D | 2E | 2F | 30 | 31 | 32   | 33 | 34  | 35 | 16 |
| 17   | 18  | 19  | 1A | 1B  | 1C  | 1D  | 1 E | 1F   | 20  | 21  | 22  | 23  | 24  | 25  | 26 | 27 | 28 | 29 | 2A | 2B   | 2C | 2D | 2E | 2F | 30 | 31 | 32 | 33   | 34 | 35  | 36 | 17 |
| 18   | 19  | 1A  | 1B | 1C  | 1D  | 1E  | 1F  | 20   | 21  | 22  | 23  | 24  | 25  | 26  | 27 | 28 | 29 | 2A | 2B | 2C   | 2D | 2E | 2F | 30 | 31 | 32 | 33 | 34   | 35 | 36  | 37 | 18 |
| 19   | 1A  | 1B  | 1C | 1 D | 1E  | 1F  | 20  | 21   | 22  | 23  | 24  | 25  | 26  | 27  | 28 | 29 | 2A | 2B | 2C | 2D   | 2E | 2F | 30 | 31 | 32 | 33 | 34 | 35   | 36 | 37  | 38 | 19 |
| 1A   | 1B  | 1C  | 1D | 1E  | 1F  | 20  | 21  | 22_  | 23  | 24  | 25  | 26_ | 27  | 28  | 29 | 2A | 2B | 2C | 2D | 2E   | 2F | 30 | 31 | 32 | 33 | 34 | 35 | 36   | 37 | 38  | 39 | 1A |
| 1B   | 1C  | 10  | 1E | 1F  | 20  | 21  | 22  | 23   | 24  | 25  | 26  | 27  | 28  | 29  | 2A | 2B | 2Ç | 2D | 2E | 2F   | 30 | 31 | 32 | 33 | 34 | 35 | 36 | 37   | 38 | 39  | 3A | 1B |
| 1C   | 1D  | 1E  | 1F | 20  | 21  | 22  | 23  | 24   | 25  | 26  | 27  | 28  | 29  | 2A  | 2B | 2C | 2D | 2E | 2F | 30   | 31 | 32 | 33 | 34 | 35 | 36 | 37 | 38   | 39 | 3A  | 3B | 1C |
| 1D   | 1 E | 1F  | 20 | 21  | 22  | 23  | 24  | 25   | 26  | 27  | 28  | 29  | 2A  | 2B  | 2C | 2D | 2Ē | 2F | 30 | 31   | 32 | 33 | 34 | 35 | 36 | 37 | 38 | 39   | 3A | 38  | 3C | 1D |
| 1E   | 1F  | 20  | 21 | 22  | 23  | 24  | 25  | 26   | 27  | 28  | 29  | 2A  | 2B  | 2C  | 2D | 2E | 2F | 30 | 31 | 32   | 33 | 34 | 35 | 36 | 37 | 38 | 39 | 3A   | 3B | 3C  | 3D | 1E |
| 1F   | 20  | 21  | 22 | 23  | 24  | 25  | 26  | 27   | 28  | 29  | 2A  | 28  | 2C  | 2D  | 2E | 2F | 30 | 31 | 32 | 33   | 34 | 35 | 36 | 37 | 38 | 39 | 3A | 3B   | 3C | 3D  | 3E | 1F |
|      | 1   | 2   | 3  | 4   | 5   | 6   | 7   | 8    | 9   | Α   | В   | С   | D   | E   | F  | 10 | 11 | 12 | 13 | 14   | 15 | 16 | 17 | 18 | 19 | 1A | 1B | 1C   | 1D | 1 E | 1F |    |

Table C-5. Powers of 16

|   |            |     | 16 <sup>n</sup> |     |     |     | n  |
|---|------------|-----|-----------------|-----|-----|-----|----|
|   |            |     |                 |     |     | 1   | 0  |
| 1 |            |     |                 |     |     | 16  | 1  |
|   |            |     |                 |     |     | 256 | 2  |
| 1 |            |     |                 |     | 4   | 096 | 3  |
| • |            |     |                 |     | 65  | 536 | 4  |
|   |            |     |                 | 1   | 048 | 576 | 5  |
|   |            |     |                 | 16  | 777 | 216 | 6  |
|   |            |     |                 | 268 | 435 | 456 | 7  |
|   |            |     | 4               | 294 | 967 | 296 | 8  |
|   |            |     | 68              | 719 | 476 | 736 | 9  |
|   |            | 1   | 099             | 511 | 627 | 776 | 10 |
| 1 |            | 17  | 592             | 186 | 044 | 416 | 11 |
|   |            | 281 | 474             | 976 | 710 | 656 | 12 |
|   | 4          | 503 | 599             | 627 | 370 | 496 | 13 |
|   | <b>7</b> 2 | 057 | 594             | 037 | 927 | 936 | 14 |
| 1 | 152        | 921 | 504             | 606 | 846 | 976 | 15 |

These powers of 16 are especially useful in determining the value of floating-point numbers.

Table C—6. Powers of 2

| Г  |       |     |     |                |     |                 |         |            |     |     |     |     |     |     |     |     |     |     |   |
|----|-------|-----|-----|----------------|-----|-----------------|---------|------------|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|---|
| ١  |       |     |     | 2 <sup>n</sup> | n   | 2 <sup>-n</sup> |         |            |     |     |     |     |     |     |     |     |     |     |   |
| r  |       |     |     | 1              | 0   | 1.0             |         |            |     |     |     |     |     |     |     |     |     |     |   |
| ı  |       |     |     | 2              | 1   | 0.5             |         |            |     |     |     |     |     |     |     |     |     |     |   |
| ı  |       |     |     | 4              | 2   | 0.25            |         |            |     |     |     |     |     |     |     |     |     |     |   |
| ı  |       |     |     | 8              | 3   |                 |         |            |     |     |     |     |     |     |     |     |     |     |   |
| ı  |       |     |     | 8              | 3   | 0.125           |         |            |     |     |     |     |     |     |     |     |     |     |   |
| Į. |       |     |     | 40             | ١.  | 0.000           | -       |            |     |     |     |     |     |     |     |     |     |     |   |
| ı  |       |     |     | 16             | 4   | 0.062           | 5<br>25 |            |     |     |     |     |     |     |     |     |     |     |   |
| l  |       |     |     | 32             | 5   | 0.031           |         |            |     |     |     |     |     |     |     |     |     |     |   |
| 1  |       |     |     | 64             | 6   | 0.015           | 625     | _          |     |     |     |     |     |     |     |     |     |     |   |
| ١  |       |     |     | 128            | 7   | 0.007           | 812     | 5          |     |     |     |     |     |     |     |     |     |     |   |
| ı  |       |     |     | 050            | ١ , | 0.000           | 000     | 25         |     |     |     |     |     |     |     |     |     |     |   |
| ı  |       |     |     | 256            | 8   | 0,003           | 906     | 25         |     |     |     |     |     |     |     |     |     |     |   |
| ı  |       |     |     | 512            | 9   | 0.001           | 953     | 125        | -   |     |     |     |     |     |     |     |     |     |   |
| ı  |       |     | 1   | 024            | 10  | 0.000           | 976     | 562        | 5   |     |     |     |     |     |     |     |     |     |   |
| ı  |       |     | 2   | 048            | 11  | 0.000           | 488     | 281        | 25  |     |     |     |     |     |     |     |     |     |   |
| 1  |       |     |     | 000            | ۱., | 0,000           | 244     | 140        | COE |     |     |     |     |     |     |     |     |     |   |
| 1  |       |     | 4   | 096            | 12  | 0.000           | 244     | 140        | 625 | -   |     |     |     |     |     |     |     |     |   |
| Т  |       |     | 8   | 192            | 13  | 0.000           | 122     | 070<br>035 | 312 | 5   |     |     |     |     |     |     |     |     |   |
| ı  |       |     | 16  | 384            | 14  | 0.000           | 061     |            | 156 | 25  |     |     |     |     |     |     |     |     |   |
| ı  |       |     | 32  | 768            | 15  | 0.000           | 030     | 517        | 578 | 125 |     |     |     |     |     |     |     |     |   |
| ı  |       |     | 65  | 536            | 16  | 0.000           | 015     | 258        | 789 | 062 | 5   |     |     |     |     |     |     |     |   |
| ı  |       |     | 131 | 072            | 17  | 0.000           | 007     | 629        | 394 | 531 | 25  |     |     |     |     |     |     |     |   |
| ı  |       |     | 262 | 144            | 18  | 0.000           | 003     | 814        | 697 | 265 | 625 |     |     |     |     |     |     |     |   |
| ı  |       |     | 524 | 288            | 19  | 0.000           | 003     | 907        | 348 | 632 | 812 | 5   |     |     |     |     |     |     |   |
| Ĺ  |       |     | 324 | 200            | 19  | 0.000           | 001     | 907        | 340 | 032 | 012 | 5   |     |     |     |     |     |     |   |
| ı  |       | 1   | 048 | 576            | 20  | 0.000           | 000     | 953        | 674 | 316 | 406 | 25  |     |     |     |     |     |     |   |
| L  |       | 2   | 097 | 152            | 21  | 0.000           | 000     | 476        | 837 | 158 | 203 | 125 |     |     |     |     |     |     |   |
| ı  |       | 4   | 194 | 304            | 22  | 0.000           | 000     | 238        | 418 | 579 | 101 | 562 | 5   |     |     |     |     |     |   |
| ı  |       | 8   | 388 | 608            | 23  | 0.000           | 000     | 119        | 209 | 289 | 550 | 781 | 25  |     |     |     |     |     |   |
| l  |       | Ü   | 555 | 000            |     | 0.000           |         |            | 200 | 200 | 000 | ,   | 20  |     |     |     |     |     |   |
| 1  |       | 16  | 777 | 216            | 24  | 0.000           | 000     | 059        | 604 | 644 | 775 | 390 | 625 |     |     |     |     |     |   |
|    |       | 33  | 554 | 432            | 25  | 0.000           | 000     | 029        | 802 | 322 | 387 | 695 | 312 | 5   |     |     |     |     |   |
| 1  |       | 67  | 108 | 864            | 26  | 0.000           | 000     | 014        | 901 | 161 | 193 | 847 | 656 | 25  |     |     |     |     |   |
| 1  |       | 134 | 217 | 728            | 27  | 0.000           | 000     | 007        | 450 | 580 | 596 | 923 | 828 | 125 |     |     |     |     |   |
| 1  |       |     |     |                | -   |                 |         |            |     |     |     |     |     |     |     |     |     |     |   |
| 1  |       | 268 | 435 | 456            | 28  | 0.000           | 000     | 003        | 725 | 290 | 298 | 461 | 914 | 062 | 5   |     |     |     |   |
| ı  |       | 536 | 870 | 912            | 29  | 0.000           | 000     | 001        | 862 | 645 | 149 | 230 | 957 | 031 | 45  |     |     |     |   |
| ł  | 1     | 073 | 741 | 824            | 30  | 0.000           | 000     | 000        | 931 | 322 | 574 | 615 | 478 | 515 | 625 |     |     |     |   |
| ı  | 2     | 147 | 483 | 648            | 31  | 0.000           | 000     | 000        | 465 | 661 | 287 | 307 | 739 | 257 | 812 | 5   |     |     |   |
| Ţ  |       |     |     |                |     | j               |         |            |     |     |     |     |     |     |     |     |     |     |   |
| 1  | 4     | 294 | 967 | 296            | 32  | 0.000           | 000     | 000        | 232 | 830 | 643 | 653 | 869 | 628 | 906 | 25  |     |     |   |
| ĺ  | 8     | 589 | 934 | 592            | 33  | 0.000           | 000     | 000        | 116 | 415 | 321 | 826 | 934 | 814 | 453 | 125 |     |     |   |
| ĺ  | 17    | 179 | 869 | 184            | 34  | 0.000           | 000     | 000        | 058 | 207 | 660 | 913 | 467 | 407 | 226 | 562 | 5   |     |   |
| 1  | 34    | 359 | 738 | 368            | 35  | 0.000           | 000     | 000        | 029 | 103 | 830 | 456 | 733 | 703 | 613 | 281 | 25  |     |   |
| 1  |       |     |     |                |     |                 |         |            |     |     |     |     |     |     |     |     |     |     |   |
| 1  | 68    | 719 | 476 | 736            | 36  | 0.000           | 000     | 000        | 014 | 551 | 915 | 228 | 366 | 851 | 806 | 640 | 625 |     |   |
| ı  | 137   | 438 | 953 | 472            | 37  | 0.000           | 000     | 000        | 007 | 275 | 957 | 614 | 183 | 425 | 903 | 320 | 312 | 5   |   |
| 1  | 274   | 877 | 906 | 944            | 38  | 0.000           | 000     | 000        | 003 | 637 | 978 | 807 | 091 | 712 | 951 | 660 | 156 | 25  |   |
|    | 549   | 755 | 813 | 888            | 39  | 0.000           | 000     | 000        | 001 | 818 | 989 | 403 | 545 | 856 | 475 | 830 | 078 | 125 |   |
| ١  |       |     |     |                |     |                 |         |            |     |     |     |     |     |     |     |     |     |     |   |
| 1  | 1 099 | 511 | 627 | 776            | 40  | 0.000           | 000     | 000        | 000 | 909 | 494 | 701 | 772 | 928 | 237 | 915 | 039 | 062 | 5 |

#### **FLOATING-POINT MATH**

The floating-point instruction set is added to the instruction repertoire as part of the floating-point control feature. An operation exception results if a floating-point instruction is issued to a processor in which the floating-point control feature has not been installed.

The floating-point instruction set provides for loading, adding, subtracting, comparing, multiplying, dividing, storing, and sign control of short or long format floating-point operands. Four double-word floating-point registers are provided to accommodate storing and loading of results and operands. These registers are numbered 0, 2, 4, and 6. The specification of any other register number results in a specification exception. For long format operands, the entire double-word register is involved in the operation. For short format operands, excluding the product in the *short format multiply* (ME) instruction, only the most significant word of the double-word register is involved in the operation. The least significant word remains unchanged. Separate instructions are provided for operations with long and short format operands.

Each operand is treated as a floating-point number consisting of a biased exponent (characteristic) and a signed fraction (mantissa). The biased exponent is expressed in excess-64 binary notation; the fraction is expressed as a hexadecimal number having an arithmetic point to the left of the high-order digit. The quantity expressed by the full floating-point number is the product of the fraction and the number 16 raised to the power of the biased exponent minus 64 (fraction times  $16^{n}$ —64).

A quantity may be represented with the greatest precision by a floating-point number of a given fraction length when the number is in a "normalized" form. A normalized floating-point number has a nonzero, high-order hexadecimal fraction digit.

An exponent overflow exception develops if, in the result of a floating-point instruction, the characteristic of the result exceeds 127 and the fraction of the result is not zero. An exponent underflow exception develops if the characteristic is less than zero and the fraction of the result is not zero. An exponent overflow exception causes a program interruption. An exponent underflow exception causes a program interruption if the exponent underflow mask bit f the current PSW is 1.

A floating-point number having a zero characteristic, a zero fraction, and a positive (zero) sign is said to be a "true zero" number.

The floating-point instructions are available in RR and RX formats. Therefore, at least one of the operands is contained in one of the floating-point registers. The other operand is located in the same or another register or in main storage. Each main storage address may be specified as relative or absolute.

To increase the precision of certain computations, an additional least significant digit, the guard digit, is carried within the hardware in the intermediate result of the following operations: add-normalized, subtract-normalized, add-unnormalized, compare, halve, and multiply. In the execution of add-normalized, subtract-normalized, add-unnormalized, subtract-unnormalized, and compare instructions, when a right shift of the fraction is required to equalize two exponents, the last hexadecimal digit to be shifted out of the least significant digit position of the fraction is saved by the processor hardware as the guard digit. The shifted fraction, including the guard digit, is used in computing the intermediate result. In the halve instruction, the least significant bit position of the fraction is saved as the fifteenth digit of the fraction of the intermediate product. If the intermediate result is subsequently normalized, the guard digit is shifted left to become part of the normalized fraction.



## LONG FORM FLOATING-POINT NUMBER



# Floating-Point Addition

Floating-point addition consists of exponent equalization and fraction addition. If the exponents are equal, the fractions are added to form an intermediate sum. If the exponents are unequal, the smaller exponent is subtracted from the larger. The difference indicates the number of hexadecimal digit shifts to the right to be performed on the fraction having the smaller exponent. Each hexadecimal digit shift to the right causes the exponent to be increased by 1. After equalization, the fractions are added to form an intermediate sum.

A carry-over digit of the most significant hexadecimal digit position of the intermediate sum causes the intermediate sum to be shifted right one digit position and the exponent to be increased by 1. If an exponent overflow condition occurs, the resultant floating-point number consists of a normalized and correct fraction, a correct sign, and an exponent which is 128 less than the correct value.

## Normalization

The intermediate sum is composed of 14 hexadecimal digits, a guard digit, and a possible carry-over digit. If any most significant digits of the intermediate sum are zero, the fraction including the guard digit is shifted left to form a normalized fraction. Vacated least significant digit positions are zero filled, and the exponent is reduced by the number of shifts. If normalization is unnecessary, the guard digit is 1.

## Exponent Underflow

If normalization causes the exponent to become less than zero, an exponent underflow condition results. If the exponent underflow mask bit (38) of the current program status word (PSW) is 1, the resultant floating-point number has a correct and normalized fraction, a correct sign, and an exponent which is 128 more than the current value. If the exponent underflow mask of the current PSW is zero, the result is a true zero.

#### Zero Result

If the intermediate sum, including the guard digit, is zero, a significance exception exits. If the significance mask bit (39) of the current PSW is 1, the result is not normalized and the exponent remains unchanged. If the significance mask bit of the current PSW is zero and the intermediate sum is zero, the result is made a true zero. Exponent underflow cannot occur for a zero fraction.

## ■ Sign

The sign of an arithmetic result is determined algebraically. The sign of a result with a zero fraction is always positive.

# Floating-Point Division

Floating-point division consists of exponent subtraction and fraction division. The intermediate quotient exponent is obtained by subtracting the exponents of the two operands and increasing the difference by 64.

Both operands are normalized before division. Consequently, the intermediate quotient is correctly normalized or a right shift of one digit position may be required. The exponent of the intermediate result is increased by 1 if the shift is necessary. All operand 1  $(r_1)$  fraction digits are used in forming the quotient, even if the normalized operand 1 fraction is larger than the normalized operand 2 fraction.

If the final quotient exponent exceeds 127, an exponent overflow exception results. The quotient consists of the correct and normalized fraction, a correct sign, and an exponent which is 128 less than the correct value.

If the final quotient exponent is less than zero, an exponent underflow condition exists. If the exponent underflow mask bit of the current PSW is 1, the quotient has a correct and normalized fraction, a correct sign, and an exponent which is 128 greater than the correct value. If the exponent underflow mask bit of the current PSW is zero, the result is made a true zero. Underflow does not apply to the intermediate result or the operands during normalization. An exponent underflow exception causes a program interrupt if the exponent underflow mask bit of the current PSW is 1.

Attempted division by a divisor with a zero fraction leaves the dividend unchanged, and a program exception for floating-point divide occurs. When division of a zero dividend is attempted, the quotient fraction is zero. The quotient sign and exponent are made zero and give a true zero result. No program exceptions occur.

# Floating-Point Multiplication

Floating-point multiplication consists of exponent addition and fraction multiplication. The exponent of the intermediate product is obtained by adding the exponents of the two operands and reducing the sum by 64.

Both operands are normalized before multiplication and the intermediate product is normalized after multiplication. The intermediate product fraction is truncated to 14 digits and a guard digit before normalization.

If the exponent of the final product exceeds 127, an exponent overflow condition exists. The resultant floating-point number consists of a correct and normalized fraction, a correct sign, and an exponent which is 128 less than the correct value. The overflow condition does not occur for an intermediate product exponent exceeding 127 if the final exponent is brought within range during normalization.

If the final product exponent is less than zero, an exponent underflow condition exists. If the exponent underflow mask bit (38) of the current PSW is 1, the resultant floating-point number has a correct and normalized fraction, a correct sign, and an exponent which is 128 greater than the correct value. If the exponent underflow mask bit of the current PSW is zero, the result is made a true zero. When an underflow characteristic becomes less than zero during normalization before multiplication, an underflow exception is not recognized.

When all digits of the intermediate product are zero, the result is made a true zero.

When the resulting fraction is zero, a program exception for exponent underflow or overflow does not occur.

|  | • |  |        |
|--|---|--|--------|
|  |   |  |        |
|  |   |  |        |
|  |   |  |        |
|  |   |  |        |
|  |   |  |        |
|  | · |  | ·<br>· |

Appendix D. Source Corrections

\$100 m

PAGE

The OS/3 assembler supports a source module correction routine. This routine is the same as the one used in the librarian. The correction deck is interchangeable between the assembler and the librarian except the librarian also uses the added COR control statement. The corrections made to the source module are temporary. The corrections are specified by the presence of both the source module input ( $//\Delta$ PARAM $\triangle$ IN=module name or the IN=(vol-ser-no, label) for the jproc call), and the correction records in the job control stream. These records must be within the data delimiters (/\$ and /\*). If there are no records between the data delimiters, no source correction is performed.

There are three control statements associated with the correction routine: sequence (SEQ), recycle (REC), and skip (SKI). To make the source module corrections, the actual source record to be inserted is used as the correction card with the same sequence number as the record to be replaced. Insertions are performed by using at least one correction card (always the first card) with a sequence number falling between the sequence numbers of the records between which the insertion is to be made. Any number of unsequenced correction cards may then follow the first sequence card. Deletions are performed by bypassing one or more original source module records in the old data set, thus eliminating them from being written on the new data set. The SKI and REC statements are used for this function.

# **PARAM**

The PARAM statement specifies the assembler processing options in effect at assembly time and alters the standard default options. If you don't specify assembler options in the control stream of your job, the assembler functions as follows:

- The assembler searches only the system source library file (\$Y\$SRC) for any source module or copy code referenced.
- It also searches only the system macro library file (\$Y\$MAC) for any macro references.
- It stores the object module produced in the job run library file (\$Y\$RUN).
- It prints the source code, object code, cross-references, and diagnostic listings.
- The value of &SYSPARM is equal to a null string.
- Columns 1 and 2 must contain slashes, followed by at least one blank column, and then PARAM followed by at least one blank column. Multiple options are supported for each option separated by commas. The end of the selected options is indicated by a blank column following the last option. All options selected are printed preceding the assembly listing.

#### Format:

The parameter definitions are as follows:

#### COPY=

Enables up to two files to identified as source code module libraries or specifies that no files are to be searched for source code modules. If this option is omitted, \$Y\$SRC is assumed and is the only file searched for source code module references. Only source code modules can be copied; the source code must be in the standard format and may not contain any COPY, ICTL, MACRO, PROC, or MEND directives.

## filename1

Specifies that the file identified as filename1 is searched first for source code modules referenced and, if not found there, then \$Y\$SRC is searched: filename is any name you specify or the system source library. If filename1 = filename2, then COPY = filename1 will generate the same files to be searched as COPY = /filename2 except that in the first case the order that the files are searched in will be filename1 and then \$Y\$SRC; whereas in the 2nd case the order will be \$Y\$SRC and then filename2.

#### filename1/filename2

Specifies that the file identified as filename1 is searched first. Then, the file identified as filename2 is searched for source code modules referenced. When two filenames are specified for this parameter, the \$Y\$SRC file is not searched.

#### filename1/(N)

Specifies only the file identified as filename1 as searched for source code modules referenced, as stated above, if filename1 = filename2, then COPY=filename1/(N) is the same as COPY = (N)/filename2 with only one file searched in either case.

#### (N)

Specifies no files, not even Y\$SRC, are searched for source code modules referenced. COPY = (N)/(N) is the same as COPY=(N).

## IN=

Identifies the name of the source module that is to be assembled and the file in which it resides. If this option is omitted, the source code must be in the control stream.

## modulename

Specifies the name of the source module and directs the assembler to search the \$Y\$SRC file for the module; modulename is the name of the source module and is up to eight characters.

#### modulename/filename

Specifies the name of the source module and the file in which it resides; filename is any name you supply or the system source library.

#### LIN=

Enables up to two files to be identified as macro source files or no files to be searched for macro references. If this option is omitted, \$Y\$MAC is assumed and is the only file searched.

#### filename1

Identifies the file that is searched for macro references and, if not found there, then \$Y\$MAC is searched; filename is any name or the name of the system macro library.

#### filename1/filename2

Identifies the two files that are searched for macro references. The file identified as filename1 is searched first, followed by the file identified as filename 2. The \$Y\$MAC file is not searched.

#### filename1/(N)

Specifies only the file identified as filename1 is searched for macro references.

(N)

Specifies no files, not even \$Y\$MAC, are searched for macro references.

#### LST=

Indicates the type of listing desired. If this option is omitted, source, object, corss-reference, and diagnostic listings are printed.

A single specification requiring no parentheses.

#### $([s_1]...[,s_4])$

Any s in the series is one of the following:

NC

Specifies that cross-reference listings are suppressed.

ND

Specifies that diagnostic listings are suppressed.

NR

Specifies that the cross-reference listing is to contain only those symbols that have at least one reference each. If specified with the NC option, NC overrides NR.

N Specifies a proc or macro debug mode feature within the OS/3 assembler. When the feature is selected, the output listing shows the following:

# DBG

Specifies a proc or macro debug mode feature within the OS/3 assembler. When the feature is selected, the output listing shows the following:

- Results of the expansion of any proc or macro called within the user program, including any conditional assembly directives processed as the result of the expansion itself. Source coding (constants, directives, and instructions) is listed twice and shows any appropriate substitutions. Any statements causing error diagnostics show the exit line in error.
- A proc or macro which produces error diagnostics at the time it is encoded is listed following the END directive; e.g., system errors. A proc or macro is encoded once, but may be called multiple times.
- If an error is detected at both expansion and encoding time, it appears two or more times. Errors detected only at encoding time appear once following the END directive.

# **PARAM**

All lines flagged (regardless of their order or appearance) are shown in the diagnostic summary list. Lines flagged at encoding time may or may not be flagged at expansion time.

When this feature is not selected, any errors detected during proc or macro expansion may not show the exact line in error, but rather the vicinity of the item which is flagged.

#### OUT=

Enables you to specify the file that is to be used to store the object module output by the assembler. If this option is omitted, the object module is generated and stored in \$Y\$RUN, the system-run library.

#### filename

Identifies the file that is used as the output file by the assembler; filename is any name or the job run library.

(N)

Specifies that no output file is used by the assembler and, thus, no object module is generated.

#### RØ=

Permits you to optionally flag all absolute/base displacement fields of instructions that yield values less than 4096 (1000<sub>16</sub>). Each statement is flagged with an 'ADDRESSABILITY' error flag.

## SYSPARM=

Specifies the equivalent of a global SETC symbol, with the value specified in this option. If this option is omitted, the value of &SYSPARM is a null string.

#### 'string'

Specifies a string of one to eight characters enclosed in apostrophes. An apostrophe within the string is represented by two apostrophes but only counts as one in determining the length of the string.

## **Operational Consideration:**

The value established by SYSPARM is available within the assembly, both outside of and within macro definitions. This parameter is referenced as &SYSPARM within assembly statements. Any error in this specification directs the assembler to ignore the specification, and an appropriate error message is printed on the output printer.

# **SEQ**

#### Function:

Specifies the starting position and the length of the sequence field. If the sequence field is omitted, column 73 is assumed to be the first column of the sequence field and continue to the maximum of eight characters.

## Format:

| LABEL  | $\Delta$ OPERATION $\Delta$ | OPERAND                                | 73<br>SEQUENCE |
|--------|-----------------------------|----------------------------------------|----------------|
| unused | d SEQ                       | ,, { column position }, { content } 73 |                |

## Parameters:

# column position

Specifies the first column position in the source record where the sequence field begins.

If omitted, column 73 is assumed to be the first column of the sequence field.

# content

One- to eight-character value. The length of this value determines the length of the sequence field.

#### NOTES:

- 1. Card column 1 must be blank if the sequence field does not start in card column 1.
- 2. The SEQ card always is the first card in the correction routine.

# **REC**

#### Function:

Causes the record pointer for the input module to be repositioned back to the first record in the module. In conjunction with the SKI control statement, it allows rearranging of major segments of the input module. When a REC control statement is processed, records are read from the input module up to and including the record whose sequence number matches the sequence number in the REC control statement field. Then, the record pointer for the input module is reset to the first record in the module. If the sequence field of the REC control statement is blank, repositioning of the record pointer takes place immediately.

#### Format:

| LABEL   | $\Delta$ operation $\Delta$ | OPERAND | 73<br>SEQUENCE      |
|---------|-----------------------------|---------|---------------------|
| ignored | REC                         | unused  | [last-sequence-no.] |
|         |                             |         |                     |

#### Parameters:

#### last-sequence no.

One to eight alphanumeric characters identifying the sequence number of the last input record to be read from the input module.

If omitted, the repositioning function takes place immediately.

#### NOTES:

- Records are replaced one at a time by writing a source statement with a sequence number matching the sequence number of the record to be replaced.
- Records are inserted by writing source correction statements with sequence numbers that fall
  between the sequence numbers of the input records between which insertion is to take place. Blank
  sequence fields cause an insertion to take place immediately.

# SKI

## Function:

Allows one or more original input module records to be bypassed. Records are read from the input module until a sequence number is detected that matches the sequence number of the SKI command. The skip operation is started and continues until a sequence number that matches the operand field of the SKI command is detected. If the sequence field of the skip command is blank, the function is started immediately.

#### Format:

| LABEL   | $\Delta$ OPERATION $\Delta$ | OPERAND           | 73<br>SEQUENCE          |
|---------|-----------------------------|-------------------|-------------------------|
| ignored | SKI                         | last-sequence-no. | [starting-sequence-no.] |
|         |                             |                   |                         |

#### Parameters:

#### last-sequence-no.

One to eight alphanumeric characters identifying the sequence number of the last input module record to be bypassed.

# starting-sequence-no.

One to eight alphanumeric characters identifying the sequence number of the first source module record to be bypassed.

If omitted, the skip operation is started immediately, starting with the input module record that immediately follows the last record operated on.

Appendix E. System Variable Symbols

System variable symbols automatically generate values or character strings at assembly time. There are seven &SYSECT, &SYSLIST, &SYSNDX, &SYSDATE, &SYSTIME, &SYSJDATE, and system variable symbols: &SYSPARM. The following paragraphs contain the functions of each system variable symbol.

&SYSECT is a system variable symbol used to represent the name of the control section containing a macro instruction.

&SYSECT is assigned a value for each inner and outer macro instruction processed by the assembler. This value is the name of the control section containing the macro instruction. If &SYSECT is referenced in a macro definition, its substituted value is the name of the last CSECT, DSECT, or START directive that occurred prior to the macro instruction. If a named CSECT, DSECT, or START directive did not appear prior to the macro instruction, &SYSECT is assigned a null character value during the processing of the macro definition called by the macro call instruction.

Any CSECT or DSECT directives processed within a macro definition affect the value of &SYSECT for any subsequent inner macro instructions in the definition and for any outer and inner macro instructions that occur outside the current nest of macro definitions. However, the value of &SYSECT remains constant during the processing of a given macro instruction, and it is not affected by CSECT or DSECT directives or inner macro instructions occurring in that macro definition.

&SYSLIST is a system variable symbol.

Within a macro definition in macro format, each positional parameter may be referenced by a name; however, each positional parameter need not be named in the macro prototype statement and may be referenced in terms of its position within the macro instruction operand field by writing the system variable symbol &SYSLIST followed by an expression in parentheses. The value of the expression identifies the position of the parameter in the operand field. The expression may be a SETA symbol or a self-defining term. Therefore, if a macro definition prototype statement has the operand field:

#### &A,&B,&C

the first positional parameter is referenced either as &A or &SYSLIST(1), the second is referenced either as &B or &SYSLIST(2), and the third positional parameter is either &C or &SYSLIST(3), and so on. This capability, which is used to index through the positional parameters, treats each parameter in the same way.

A null character string is generated in place of &SYSLIST(m) if m is zero or greater than the number of positional parameters supplied in the macro instruction.

The system variable &SYSLIST may not be used in a mixed-mode (positional and keyword parameters included) macro definition.

&SYSNDX is a system variable symbol.

The assembler maintains a counter that is incremented by 1 each time the assembler encounters a macro instruction. The value of this counter within the first macro is 1. The current value of this counter is supplied as the 4-digit character value of the system variable symbol &SYSNDX each time a macro instruction is encountered. A macro definition that defines labels within the code it generates and that may be called more than once in a single assembly generally creates duplicate definitions of the same label. To avoid this problem, the system variable symbol &SYSNDX may be used as a suffix on the labels defined by the macro definition, so that each time the macro definition is called, it will define a different set of labels.

&SYSDATE is a system variable symbol, which you can reference in your program text or within a macro definition to generate the date your program is assembled. The date is produced in your assembly listing as a character string representing the month, day, and year (mm/dd/yy) the program was assembled. If you:

- 1. assemble your program;
- 2. store it in a library; and
- 3. retrieve the assembled program for execution at a later date —

any &SYSDATE reference in your program references the original assembly date, not the current date when your program is executed.

You specify &SYSDATE as either an operand in a source code statement, which defines a constant (DC), or an operand field literal.

#### Example:

| LABEL<br>1 | ∆OPERATION /<br>10 | 16          | OPERAND    | Δ           |
|------------|--------------------|-------------|------------|-------------|
| 11111      | •                  |             |            |             |
|            | 1.1.1.1            | 1.          |            |             |
|            |                    | 1.          |            |             |
| ASMDAITE   | DC                 | <u> </u> C' | (&sysdate) |             |
|            |                    | 1           | <u> </u>   | <del></del> |

When this line of source code is assembled, the object code contains the current date.

You can also use the &SYSDATE system variable symbol as a literal.

# Example:

|          | 1                    |
|----------|----------------------|
| •1 , , , |                      |
|          |                      |
| MVC      | BUF, CI' & SYSIDATE' |
|          |                      |

When this line of source code is executed, the assembly date is moved into a main storage area called BUF.

&SYSTIME is a system variable symbol, which you can reference either in your program text or within a macro definition, to generate the time of day your program is assembled. The date is produced in your assembly listing as a character string representing the hour, minute, and second (hh.mm.ss) the assembly was run. If you:

- 1. assemble your program;
- 2. store it in a library; and
- 3. retrieve the assembled program for execution at another time —

PAGE

any &SYSTIME reference in your program references the original assembly time, not the current time of execution.

You specify &SYSTIME as either an operand in a source code statement, which defines a constant (DC), or an operand field literal.

## Example:



When this line of source code is assembled, the object code contains the current time.

You can also use the &SYSTIME system variable symbol as a literal.

## Example:

| 1           | 11 1 | 1                     |
|-------------|------|-----------------------|
| 11111       | •    | BUF, = C'&SYST, IME?  |
| 1 1 1 1 1 1 | •    |                       |
|             | MIVC | BUF. = C' & SYISTIME? |
|             |      |                       |

When this line of source code is executed, the assembly time is moved into a main storage area called BUF.

&SYSJDATE is a system variable symbol, which you can reference either in your program text or within a macro definition, to generate the Julian date when your program is assembled. The date is produced in your assembly listing as a character string representing the month, day, year, and Julian value — day of the year (mmddyjjj) the assembly was run. If you:

- 1. assemble your program;
- 2. store it in a library; and
- 3. retrieve the assembled program for execution at another time —

any &SYSJDATE reference in your program references the Julian date of the original assembly.

You specify &SYSJDATE as either an operand in a source code statement, which defines a constant (DC), or an operand field literal.

Example:

|               |    | 1             |
|---------------|----|---------------|
|               |    |               |
|               |    |               |
| J.U.L.D.AIT.E | DC | C'BSYSJ,DATE' |
|               |    |               |

When this line of source code is assembled, the object code contains the Julian date.

You can also use the &SYSJDATE system variable symbol as a literal.

Example:

|   | •         |                                         |
|---|-----------|-----------------------------------------|
| 1 | 4         | 1,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,, |
|   | • • • • • |                                         |
|   | MVG       | BUF = C'. & 3. Y S J. D. A.T. E. ?      |
|   |           |                                         |

When this line of source code is executed, the Julian date is moved into a main storage area called BUF.

&SYSPARM is a system variable symbol, which you can reference either in your program text or within a macro definition, to generate an 8-byte null character string at assembly time. The string is initially null but can be varied by using the PARAM statement (Section 3) as follows:

| LABEL              | $\Delta$ OPERATION $\Delta$ | OPERAND |
|--------------------|-----------------------------|---------|
| //∆ <b>PARAM</b> ∆ | SYSPARM='string'            |         |

By using the PARAM statement, you can specify a string of up to eight characters, enclosed in apostrophes. Once you've altered the value of &SYSPARM, any references to &SYSPARM produces the character string you specified in the PARAM statement, not a null character string.

To reference the &SYSPARM system variable symbol, you specify &SYSPARM as either an operand in a source code statement, which defines a constant (DC), or an operand field literal.

Example:

| LABEL<br>1     | △OPERATION 10 | ∆<br>16 | OPERAND    | Δ        |
|----------------|---------------|---------|------------|----------|
| 114111         | •             |         |            |          |
|                | • 1 1 1       |         |            |          |
|                | •             | 1       |            |          |
| N,U,LS,TIR,N,G | ם <u>וכ</u> ו | C'      | '&sysparm' | <u> </u> |
|                | •             |         |            |          |

PAGE

When this line of source code is assembled, the object code contains an 8-byte null character string.

You can also use the &SYSPARM system variable symbol as a literal.

Example:



If you don't precede this source code statement with a PARAM statement when this line of source code is executed, an 8-byte null character string is moved into a main storage area called BUF.

|   |   | • |            |
|---|---|---|------------|
| · |   |   |            |
|   |   |   |            |
|   | · |   |            |
|   |   |   |            |
|   |   |   |            |
|   |   |   |            |
|   |   |   |            |
|   |   |   |            |
|   |   |   | 19.44<br>1 |
|   |   |   |            |

**Appendix F. Attribute References** 

 The assembler assigns certain attributes to symbols and macro call operands that you may refer to in conditional assembly statements. These attributes are: type (T), length (L), scale (S), integer (I), count (K), and number (N).

You can specify attributes in conditional assembly statements to control logic, which in turn can control the sequence and contents of the inline expansion code generated from model statements. Each kind of attribute has a specific purpose, which determines when you use it.

#### Format:

| LABEL    | $\Delta$ OPERATION $\Delta$                  |                        | OPERAND                |  |
|----------|----------------------------------------------|------------------------|------------------------|--|
| [symbol] | conditional<br>assembly<br>operation<br>code | (T)<br>SS<br>IC<br>(K) | {symbol }<br>{&symbol} |  |

The attribute notation (T, L, S, I, K, or N) denotes which attribute of a symbol or parameter you are using. The symbol or parameter is a reference to the data or field which possesses the attribute. The operation code must be a conditional assembly operation code except when you are using the length attribute.

The origin of an attribute value is always either a symbol or parameter. Table F—1 gives the restrictions for using a symbol or parameter as the reference to obtain a particular data attribute. Whether a symbol or parameter can be used in an attribute reference depends on where the reference is made. If an attribute reference is made in macro source code (from inside a macro definition), a symbol may be referenced for any data attribute except K or N. A symbol cannot be used in a count or number attribute reference in macro source code because when K or N is used inside a macro definition the only data that can be referenced is an operand field in the macro instruction call. To reference an operand field to obtain the K or N attribute you can use a symbolic parameter or &SYSLIST; this also applies to the T, L, S, and I attributes. A SET symbol and the system variable symbols listed in Table F—1 can only be used in the T and K attribute references when in macro source code. You can get all but K or N attributes of a symbol in program source code along with all of the other attributes by using the symbol in the attribute reference. Macro instruction operands cannot be referenced from program source code so a symbolic parameter or &SYSLIST cannot be part of an attribute reference in program source code. However, a SET symbol and the system variable listed in Table F—1 can be used in an attribute reference in program source code.

PAGE

Table F-1. Valid Attribute Reference Applications

|              |          | ATTRIBUTE |          |          |          | REFERENCE                                                 | LOCATION          |
|--------------|----------|-----------|----------|----------|----------|-----------------------------------------------------------|-------------------|
| Т            | L        | s         | ı        | к        | N        | REFERENCE                                                 | LOCATION          |
| $\checkmark$ | <b>√</b> | √         | <b>√</b> |          |          | Symbol                                                    |                   |
| <b>√</b>     |          |           |          | <b>√</b> |          | Set Symbol                                                |                   |
| <b>√</b>     | <b>√</b> | <b>√</b>  | <b>√</b> | <b>√</b> | <b>√</b> | Symbolic Parameter                                        | Macro             |
| <b>√</b>     | <b>√</b> | <b>√</b>  | √        | <b>√</b> | <b>√</b> | &SYSLIST                                                  | Source<br>Code    |
| <b>√</b>     |          |           |          | <b>√</b> |          | &SYSNDX, &SYSPARM,<br>&SYSJDATE, &SYSECT,<br>and &SYSTIME |                   |
| <b>√</b>     | <b>√</b> | <b>√</b>  | √        |          |          | Symbol                                                    |                   |
| <b>√</b>     |          |           |          | <b>√</b> |          | SET Symbol                                                | Program<br>Source |
| <b>√</b>     |          |           |          | <b>√</b> |          | &SYSPARM, &SYSDATE,<br>&SYSJDATE, and &SYSTIME            | Code              |

<sup>√ =</sup> Valid Application

There are two requirements that must be met before using symbols in attribute references. First, the symbol must appear either in the operand field of an EXTRN directive used outside of a macro, or in the label field of at lease one assembler directive or instruction outside a macro. Second, there must not be any variable symbol in the source line in whose label field the symbol appears. In regards to the call operand attributes, you must abide by the following criteria: the same as previously mentioned, with the addition that the operand must be a symbol and it may not be one generated by variable symbol replacement. The attributes of the operand are really the attributes of the symbol itself. A nested call operand may be a symbolic parameter whose attributes are then the same as the corresponding outer operand. You can not use a length attribute if the type attribute is J, M, N, O T, or U.

Since a call operand may be a sublist, you can also refer to attributes of a sublist or each individual parameter in the sublist. When you refer to these attributes, they will be assigned the same value as the first parameter in the sublist.

You can refer to attributes on conditional directives both inside and outside of macros. Symbols that appear in the label field of instructions generated by a macro are not assigned attributes.

#### Type attributes

You can use the type attribute to test for the characteristic of the operand or symbol. This is done by writing a T' followed by the symbol or symbolic parameter to be tested. This can also be used in SETC directive operand fields or as character expressions in SETB and AIF directive operand fields. Table F-2 summarizes the type attributes and the circumstances under which they are produced.

Table F-2, Type Attributes of Symbols (Part 1 of 2)

| Туре | Symbol<br>Definition                       | Length<br>Specification | Alignment      |
|------|--------------------------------------------|-------------------------|----------------|
| А    | Type A address constant                    | Implied                 | Full-word      |
| В    | Binary constant                            | Implied or explicit     | Not applicable |
| С    | Character<br>constant                      | Implied or explicit     | Not applicable |
| D    | Double-word<br>floating-point<br>constant  | Implied                 | Double-word    |
| E    | Full-word<br>floating-point<br>constant    | Implied                 | Full-word      |
| F    | Full-word<br>fixed-point<br>constant       | Implied                 | Full-word      |
| G    | Fixed-point constant                       | Explicit                | Not applicable |
| Н    | Half-word<br>fixed-point<br>constant       | Implied                 | Half-word      |
| l ·  | Machine instruction                        | 1mplied                 | Half-word      |
| J    | Control section name                       | Not applicable          | Double-word    |
| К    | Floating-point constant                    | Explicit                | Not applicable |
| М    | Macro instruction                          | Not applicable          | Not applicable |
| N ①  | Self-defining term                         | Not applicable          | Not applicable |
| 0 ①  | Omitted operand                            | Not applicable          | Not applicable |
| Р    | Packed decimal constant                    | Implied or explicit     | Not applicable |
| R    | Unaligned address constant (A, S, V, or Y) | Explicit                | Not applicable |
| S    | Type S address constant                    | Implied                 | Half-word      |
| т    | External symbol                            | Not applicable          | Not applicable |
| U ②  | Type not available                         | Not applicable          | Not applicable |

Table F-2. Type Attributes of Symbols (Part 2 of 2)

| Туре | Symbol<br>Definition       | Length<br>Specification | Alignment      |
|------|----------------------------|-------------------------|----------------|
| V    | Type V address<br>constant | Implied                 | Full-word      |
| w    | CCW statement              | Implied                 | Double-word    |
| х    | Hexadecimal constant       | Explicit or implied     | Not applicable |
| Y    | Type Y address<br>constant | Implied                 | Half-word      |
| Z    | Zoned decimal constant     | Explicit or implied     | Not applicable |

#### NOTES:

- This type attribute is produced only for macro instruction operands.
- Type cannot be assigned. It is produced for inner and outer macro instruction operands that cannot be assigned any other attribute, as well as for literals appearing as macro instruction operands, symbols appearing in the label field of LTORG, ORG, or EQU directives, symbols appearing more than once in a source statement label field, and symbols appearing in the label field of DC or DS directives containing expressions or variable symbols in the modifier subfields. The latter is true even if the modifier subfield expression consists solely of self-defining terms.

#### Length Attributes

You can reference the length attribute by writing an L' followed by the symbol or parameter whose attribute you want. The length attribute has a numeric value, which refers to the number of bytes assigned by the assembler to a data field. If the length attribute value is required for conditional (preassembly) processing, the symbol you specify in the attribute reference must appear in the label field of a statement in open source code. The operand field of that statement must contain a self-defining term.

The length modifier or length field must not be coded as a multiterm expression because the assembler does not evaluate this expression until assembly time.

When the length attribute is used in conditional assembly statements, it can be specified only within an expression. Examples: L'&P(4), L'&VARY(1,2), L'&SYSLIST(5).

When a length attribute reference is specified in open source code, it is not available for use in conditional assembly statements.

An L' cannot be generated directly by a macro or proc. It can be done indirectly as follows:

| LABEL<br>1 | ∆operation/<br>10                            | ∆<br>16                                 | OPERAND  | · Δ.     |
|------------|----------------------------------------------|-----------------------------------------|----------|----------|
|            | 4,0,4,0                                      | 8,A,, 8                                 | 3.B      |          |
| 8A         | SIEITICI                                     | (Z)                                     |          |          |
| &B         | SEITIG                                       | (,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,, |          | <u> </u> |
|            | M <sub>I</sub> V <sub>I</sub> C <sub>1</sub> | & <sub>1</sub> A <sub>1-1</sub>         | (&B&A),X | <u> </u> |

After generation this would result in:

MVC Z(L'Z),X

#### Scale Attributes

You can reference scale attributes of variable symbols by coding an S' followed by the desired symbol. Scaling attributes are available only for labels of statements defining fixed-point or floating-point constants. This restricts them to H, F, D, E, P, type Z, type K, and type G constants in the OS/3 assembler. The scaling attribute is the value you have assigned for the scale modifier of a fixed or floating-point constant. This modifier is an integer used to assign a number of bits in an unnormalized constant for the fractional portion of the constant. For example, the scale modifier of a DC statement such as HF8'-19.788' would be 8, since it is specifying 8 bits for the fractional part of the number. For deciaml type constants, the scaling attribute is the number of decimal digits to the right of the decimal point.

## Integer Attributes

An integer attribute can be written with an I' followed by the symbol you wish. An integer attribute is computed from length and scaling attributes and is thus also applicable only to a symbol which is the label of a statement defining fixed-point or floating-point constants (F, H, D, E, P, type Z, type K, and type G). A fixed-point integer attribute is equal to 8 times the length attribute, minus the scaling attribute, minus 1 (I'=8\*L-S'-1). For floating-point, you obtain the integer attribute by subtracting 1 from the length attribute, multiplying by 2 and subtracting the scaling attribute (I'=2\*(L'-1)-S').

A halfword fixed-point constant (H) would have a length attribute of 2 (L'=2) and a scale attribute specified as 4 (S'=4). Therefore the integer attribute would be (8x2)—8—1=7. A fullword fixed-point constant would have a length of 4 (L'=4) and a scale attribute specified here as 12 (S'=12). The integer attribute in this case would be (8x4)—12—1=19.

Since E is a floating-point fullword, its length attribute is 4 (L'=4). The scale attribute is specified to be 3 (S'=3). Thus the integer attribute is 2(4—1)—3=3. When we have a floating point doubleword constant (D), its length attribute is 8 (L'=8). The scale attribute is shown to be 6. The integer attribute we can then compute to be 2(8-1)-6=8. For decimal constants the integer attribute is the number of decimal digits to the left of the decimal point.

#### Count Attributes

You can use the count attribute of a call operand to reference the number of characters in the operand, excluding commas. This attribute is determined after substitution of any variable symbols, that is, it uses the replacement characters rather than the variable symbol to determine the count attribute. You can use the count attribute in SETA or DO operand fields, and in relational expressions of SETB and AIF operands that are within a macro.

If the operand selected is a sublist, the count attribute will include the parentheses and commas within the sublist.

## **Number Attributes**

For call operands, you can also reference the number of operands in an operand sublist. You reference the number attribute by writing an N' followed by the symbol or parameter whose attribute you want. This number is equal to 1 plus the number of commas separating or indicating the ommission of operands in the sublist. This attribute is available in SETA, DO, SETB, or AIF directives.

If an operand is not a sublist, the number attribute is 1. If an operand is omitted, its value is 0.

## Example:

| LABEL<br>1  | ∆OPERATION A   | ^<br>16            | OPERAND         | Δ                   | COMMENTS              |
|-------------|----------------|--------------------|-----------------|---------------------|-----------------------|
|             | PIROC.         | &PAR               | A <u>lM</u> , L | 1                   |                       |
| DATTR       | NAME           |                    | 1               |                     |                       |
| *DLSPILAY   | ATTRI          | BUTES              | IOF MACRO IN    | ISTRUCTION OPER     | AND LLLLLLL           |
| ·* THIS     | COMMEN         | TIS.               | NOT GENERATE    | المستنبلية بالمسترك |                       |
|             | LCLA           | <u>&amp;\$Q.,.</u> | &ID,&KQ,&NQ     | &LQ                 |                       |
|             | LCLC.          | &TQ.               | <del></del>     |                     |                       |
| 8.ID        | BETA           | I'&P               | ARAM (III)      | 1                   |                       |
| &\$Q        | SETA           | 5'&P               | ARAM (11)       | <u> </u>            | التنبيل يستنبا فيتيني |
| & KQ        | SETA           | K'&P/              | AIRAM(11)       | <u> </u>            |                       |
| &NO         | SETA           | N' &P.             | AIRAM (.l.)     |                     |                       |
| &LQ         | SETA           | L'&P               | ARAM (III)      |                     |                       |
| &TQ         | SETC           | T' &P              | AIRAM(II)       |                     |                       |
|             | DC             | C'&P/              | ARAM (11) . THI | S IS THE OPERAL     | <u> </u>              |
|             | D <sub>C</sub> | Y, (&L,            | Q1)             | IGTH ATTRIBUTE K    | DE PAIRAM             |
|             | DC             | Y. (&K             | 31)             | INT ATTRIBUTE OF    | F. PARIAM             |
|             | DC.            | Y (&I              | 91)             | EGERI ATTRIBUTE     | DE PARAM              |
|             | DC             | Y. (&S)            | 21)             | LE ATTRIBUTE DI     | FILPARAM I I I I I I  |
|             | DC             | Y.(.&.NC           | 21)             | ABER OF OPERANDS    | in Sublist            |
|             | DC             | C. 1.8.T.          | Q' TYF          | E ATTRIBUTE OF      | PARAM                 |
| <del></del> | END.           | <del> </del>       | <del></del>     |                     | <u> </u>              |

# **Glossary**

# A

# absolute expression

An expression whose value is unchanged by program relocation. The absolute expression can be an absolute term or any combination of absolute terms. Arithmetic operators are permitted between absolute terms.

Examples of absolute terms are: a symbol that has an absolute value, a self-defining term, or a length attribute reference.

Relocatable terms alone or relocatable terms in combination with absolute terms can be contained within an absolute expression. This type of absolute expression requires that each relocatable term be paired with another relocatable term that has the opposite sign and the same relocatability attribute. The paired terms need not be contiguous.

The effect of relocation is canceled by the pairing of relocatable terms with the same relocatable attribute and opposite signs. The absolute expression is thereby reduced to a single absolute value.

The following are absolute expressions:

A A+A—A A—A+A+A R+A—R R—R+A (R—R)\*A A\*A

where:

Α

Is an absolute term.

R

Is a relocatable term.

# advance listing (EJECT)

Controlled by the EJECT directive.

# arithmetic operators

The symbols +,-,\*,/,//,\*/. The intrinsic meanings of +,-,\*, and / are the usual ones; that is, + indicates addition, - indicates subtraction, \* indicates multiplication, and / indicates division.

The operator // denotes a covered quotient where A//B is equivalent to (A+B—1)/B. A covered quotient is equal to regular binary division except that if there is a remainder, a 1 is added to the regular quotient.

The operator \*/ denotes a binary shift left or right. A\*/B indicates a left shift and is equivalent to A\*2B. A\*/(—B) indicates a right shift and is equivalent to A/2B.

# C

# character expression

A character string, a character substring, or a concatenation of strings or substrings. The maximum length of a character expression is 127 characters. Character expressions are used as operands of SET and SETC statements and as terms in a SETB relational expression.

A character string is at least one of the 256 valid characters enclosed by apostrophes. A character string, unlike a character self-defining term, is not converted and treated as a binary value. The value of a character string is determined by its length. Any character string is greater in value than any shorter character string. Rules for writing character strings are:

- Two apostrophes must be written within a character string to represent one apostrophe. The two apostrophes are replaced by a single apostrophe when the string is printed.
- Two ampersands must be written within a character string to represent one ampersand. Both ampersands are retained as part of the character string. A single ampersand within the character string is interpreted as the first character of a variable symbol.

A character substring is a valid character string followed by two arithmetic expressions separated by a comma and enclosed in parentheses. The format is:

character string (e<sub>1</sub>,e<sub>2</sub>)

where:

- e<sub>1</sub>
  Specifies the leftmost character of the original character string to be included in the substring.
- e<sub>2</sub>
  Specifies the number of characters to be in the substring.

The expressions  $e_1$  and  $e_2$  must be valid SETA expressions. If there are fewer characters (than the number specified by  $e_2$ ) remaining after character number  $e_1$  in the string, the resultant substring is shortened to include only valid characters of the original string. A null character string results if  $e_1$  is greater than the number of characters in the original string.

#### character set

The overall character set of the assembler. This set is divided into the following classes:

Alphabetic set:

Alphabetic characters: the uppercase letters A through Z

Special letters: ? \$ # @

Numeric characters: 0 through 9

Special characters : +-\*/ , =  $\triangle$  (blank) () . & '><

#### comments statement

A statement that, when written within a source code statement, causes the assembler to generate comments on the output listing. This type of comments statement is written with an asterisk in column 1 of the assembler coding form followed by the comment. To continue a comment on the following line, column 72 must contain X.

A special form of the comments statement is also available for use within macro definitions. This form is used to include comments in a macro definition that are not to be generated in the output listing. This type is written with a period in column 1 of the assembler coding form, followed by an asterisk (\*) in column 2, followed by the comment.

Neither form of comments statement may be created by substitution for variable symbols. Substitution for variable symbols is not performed on comment lines.

Three statements are available for listing comments, error messages, or internal references. The PNOTE message statement may be used in either a macro definition or at the source code level. The MNOTE message statement may be used only in a macro definition. If either of these statements is generated by a macro definition, the statement will be printed, even if the NOGEN option of the PRINT statement is in effect. The comments statement may be used in macro definition form or in source code level form.

# common storage definition

A common storage area for two or more separately assembled routines.

#### complex relocatable expressions

An expression that contains either 2 to 16 unpaired relocatable terms or a negative relocatable term in addition to any absolute or paired relocatable terms.

A complex relocatable expression may be written only in the operand field of either an A-type or Y-type address constant.

Some complex relocatable expressions are:

where:

Α

Is an absolute term.

R

Is a relocatable term.

#### concatenation

The joining together of:

- two character strings;
- two character substrings; or
- a character string and a character substring.

A period designates concatenation into a single string of characters. When a substring is to be concatenated with a following character string, the period may be omitted and concatenation is assumed.

# conditional assembly

Statements used by the programmer to direct the assembler to:

- exclude lines of code from the assembler output;
- include a set of lines more than once in the assembly output; or
- establish and alter values to determine whether a set of lines should be included in the output listing.

Conditional assembly statements are used to control the pattern of coding generated within a macro definition and to define and assign values to set symbols that can be used to vary parts of generated statements.

## conditional branch (AIF)

The statement that conditionally alters the sequence of source statement processing.

## control section identification (CSECT)

The directive that indicates to the assembler the initiation or continuation of a control section.

# D

# define branch destination (ANOP)

The statement that facilitates branching by supplying a symbol in its label field.

# define end of range (ENDO)

The statement used to indicate the end of the range of a DO statement.

#### define start of range (DO)

The statement that defines the starting point of the code and the number of times it is to be generated.

## diagnostic listing

A listing of error statements. The diagnostic listing follows the assembly listing and contains a detailed accounting of any errors which occurred in the assembly. The listing contains the line number of the statement in which the error occurred, the error code, and a message indicating the cause of the error. The messages are listed in the order in which they occurred. A diagnostic listing is optional and can be suppressed by using the PARAM statement (3.22) with the LST=ND option in its operand field. The PARAM statement also provides the LST=DBG option for debugging a macro definition.

When a macro definition is retrieved from a library, the END statement is flagged if an error occurs during macro expansion. To obtain a diagnostic listing of the macro statement containing the error, you must use the LST=DBG option. If the macro definition is part of your source program, actual source statements are flagged if they contain errors. Each error is then listed in the diagnostic listing.

### dummy control section identification (DSECT)

The directive that indicates to the assembler the areas defined in other modules.

## Ε

#### expression

One or more terms connected by operators. A leading minus sign is allowed to produce the negative of the first term. Each term in the expression may be either a relocatable term or an absolute term. A term is absolute if its value is not changed by program relocation. A term is a relocatable term if its value is changed by program relocation. Two relocatable terms may be considered to be paired if they have opposite signs and have the same relocatibility attribute (that is, appear in the same control section).

Evaluation of expressions obeys the following rules:

- Multiplication and division of a relocatable term by an absolute 1 or multiplication of an absolute 1 by a relocatable term produces a relocatable term.
- Multiplication of any term by absolute 0 yields absolute 0 as a result.
- If a relocatable term enters any multiply or divide operation other than the above, an error flag is given and the result is treated as absolute.
- The number of unpaired relocatable terms at any point in the evaluation must not exceed 16.
- Intermediate results of the expression evaluation are full 32-bit values; however, the final result is the truncated rightmost 24 bits.

Three types of expressions — absolute, relocatable, and complex relocatable — obtain various characteristics from the term or terms that compose them.

## F

#### fixed-point number

A number represented in one of three fixed-length binary formats composed of a single positive or negative sign bit followed by a number field. When the sign bit is 0, the number represents a positive value; when 1, the number represents a negative value. Negative numbers are represented in twos complement notation, which is derived by inverting each bit of the binary number and adding 1 to the result of the inversion.

### **HALF WORD**



#### **FULL WORD**

|   | S I G N | number field |    |
|---|---------|--------------|----|
| ١ | 0       | 1            | 31 |

#### **DOUBLE WORD**



## G

#### **GBL**

A general purpose global set symbol.

#### **GBLA**

An arithmetic global set symbol.

### **GBLB**

A Boolean global set symbol.

## **GBLC**

A character global set system.

## generate literals (LTORG)

The directive that causes the assembler to generate literals previously defined.

## H

## high order

Leftmost data; most significant byte or bit.

## 1

## include code from a library (COPY)

The directive that includes code into the source program.

## input format control (ICTL)

The directive that specifies new-values for the begin, end, and continuation columns.

## input sequence control (ISEQ)

The directive that informs the assembler what columns contain the sequence information.

## L

#### LCI

A general purpose local set symbol.

### **LCLA**

An arithmetic local set symbol.

### **LCLB**

A Boolean local set symbol.

## **LCLC**

A character local set symbol.

## leave blank lines on listing (SPACE)

The directive that causes the assembler to advance the paper in the printer.

### length attribute of expressions

An attribute that is determined by the assembler and is a function of the leading term of the expression. If the first term of an expression is an absolute value, a length attribute of one byte is assigned to the expression. If the leading term is a symbol, the number of bytes attributed to the expression is the same as the length attributed to the symbol. Thus if TAG appears in the label field of an LH (load half word) instruction, it would have a length attribute of 4 since LH is a 4-byte instruction. In referencing the same label, the expression TAG+195 also has a length attribute of 4, but the expression 195+TAG has a length attribute of 1 because the leading term is a decimal self-defining term.

### length attribute of symbols

The number of bytes assigned to the instruction, constant, or storage area involved. For example, the label of a 2-byte instruction has a length attribute of 2, and the label of a DS statement reserving 200 bytes would have a length attribute of 200. Symbols equated to location counter references or absolute value representations usually have a length attribute of 1. The duplication factor (constant or storage area) has no effect on the length attribute.

The maximum length attribute that can be generated by the assembler is 256 bytes; however, a DS may be used to reserve more than 256 bytes of storage.

The length attribute of a symbol may be referenced as a term in an expression by writing L' followed by the symbol. Thus if the symbol STOREND is the name of a full-word field,

L'STOREND

would be considered a term and would have a length of 4 bytes.

#### listing content control (PRINT)

The directive that controls the contents of the assembly listing.

## literals

Terms that represent data in the source coding. The assembler replaces the literal with the address of the main storage location, in the literal table, of the value of the original literal. In the following example, the literal =C'AA' will be replaced in this instruction by the address of a 2-byte area in the literal table containing the binary value 11000001 11000001.

MOVEAA MVC TESTSW,=C'AA'

When the assembler recognizes a literal in the source code, it searches the table of literals that have been previously encountered. If a duplicate is found, then the relocatable address of the literal in the table replaces the original literal in the source code. If a duplicate is not found, then the value of the original literal is entered into the table and its address replaces the source code specification. Literals are similar in form to the operands of DC and DS statements.

A literal may be used in any machine instruction that specifies a storage address, except that the literal may not be specified as the receiving field operand of an instruction that modifies storage, i.e., a literal may be used only as the last operand of an application instruction. Literals may not be specified in address constants, shift instructions, or I/O instructions. Literals must always appear as the complete operand specification. They cannot be combined with other terms, nor with an explicit base register specification.

#### location counter reference

A reference maintained by the assembler for each control section created by the programmer. Each counter contains the next available location for the associated control section. After the assembler processes an instruction or constant, it adds the length of the instruction or constant processed to the correct location counter. The maximum value that the location counter can achieve is 2<sup>23</sup>—1.

Each instruction must have an address that is a multiple of two bytes. This type of address is said to fall on a half-word boundary. If the value of the location counter is not a multiple of 2 when assembling such an instruction, a 1 is added to the location counter before assigning an address to the current statement. Storage locations reserved in this way receive binary 0's when the program is loaded. Certain constants must be aligned to a half-word, full-word, or double-word boundary. Again the location counter is adjusted to the boundary, and the storage locations that were bypassed receive binary 0's when the program is loaded, unless the adjustment occurred as a result of a DS or ORG directive.

The current value of the location counter, under which the program is currently being assembled, is available for reference by the programmer. It is represented by the special character\* (asterisk). If the asterisk is written as a term in an address constant or in an instruction operand expression, this character is replaced by the storage address of the leftmost byte allocated to that instruction or constant. All such implied references must be specified appropriately, since the asterisk (\*) is also used as an arithmetic operator to indicate multiplication.

## logical operators

The symbols \*\*, ++, and ——. The characters \*\* represent the logical product (AND), the characters ++ represent the logical sum (OR), and the characters —— represent the symmetric difference, exclusive or (XOR).

Each bit of the first term is compared with its corresponding bit in the second term, and the result of the comparison is placed in the corresponding position in the resulting term. The result of the bit comparison for each operator is:

| AND  |        |  |  |  |  |  |  |  |
|------|--------|--|--|--|--|--|--|--|
| A**B | Result |  |  |  |  |  |  |  |
| 1 1  | 1      |  |  |  |  |  |  |  |
| 1 0  | 0      |  |  |  |  |  |  |  |
| 0 1  | o      |  |  |  |  |  |  |  |
| 0 0  | 0      |  |  |  |  |  |  |  |

|    | OR  |        |  |  |  |  |  |  |
|----|-----|--------|--|--|--|--|--|--|
| A+ | -+B | Result |  |  |  |  |  |  |
| 1  | 1   | 1      |  |  |  |  |  |  |
| 1  | 0   | 1      |  |  |  |  |  |  |
| 0  | 1   | 1      |  |  |  |  |  |  |
| 0  | 0   | 0      |  |  |  |  |  |  |

| X   | XOR    |  |  |  |  |  |  |  |  |
|-----|--------|--|--|--|--|--|--|--|--|
| АВ  | Result |  |  |  |  |  |  |  |  |
| 1 1 | 0      |  |  |  |  |  |  |  |  |
| 1 0 | 1      |  |  |  |  |  |  |  |  |
| 0 1 | 1      |  |  |  |  |  |  |  |  |
| 0 0 | 0      |  |  |  |  |  |  |  |  |

### low order

Rightmost data; least significant byte or bit.

#### **LSB**

Least significant bit or byte, rightmost.

## M

#### macro definition

A formalized pattern of code written once if a certain series of instructions (e.g., a routine) is needed more than once in a program or associated programs. The macro definition may be stored in a library for later use or submitted for assembly with the source code deck.

Macro definitions may be prepared in one of two separate formats: macro or proc. The elements of the macro and proc format types may not be mixed within a macro definition; however, macro definitions of both types are permitted within a program. Macro definitions contained in the source program may be preceded only by comment statements and the following assembler directives: ICTL, ISEQ, TITLE, SPACE, EJECT, and PRINT. Any of these directives except ICTL may appear between macro definitions. A macro definition within a macro definition (nesting) is not permitted in either the macro or the proc format.

#### model statements

The statements in a macro definition from which machine and assembler instructions are generated. Model statements contain from one to four entries, as follows:

- The label field may contain a symbol, a variable symbol, or a sequence symbol, depending on the operation defined. Comment statements may not be created by substitution for variable symbols.
- The operation field may contain any machine, assembler, or macro instruction mnemonic code except END, ICTL, ISEQ, or PRINT.
- Either ordinary symbols or variable symbols may be written in the operand field. The size of this field may not exceed 240 characters after substitution.
- The comments field may contain any combination of characters; however, substitution for variable symbols is not performed on this field by the assembler. Comments are written in the format of the statement the model represents.
- A macro instruction that is a model statement within a macro definition is called an inner macro instruction, while a macro instruction in the source module is called an outer macro instruction. A macro instruction that appears in a macro definition corresponding to an outer macro instruction is called a second-level macro instruction. A macro instruction that appears in the macro definition corresponds to a second-level macro instruction. Macro instructions within macro definitions are nested. The number of levels to which macro instructions may be nested in an assembly depends upon the amount of main storage available to the assembler.
- Because COPY statements within a macro definition are processed prior to the generation of code from a macro definition, they are not considered to be model statements nor are they ever processed as such.
- Model statements within a macro definition in proc format obey the same rules as model statements in macro format.

#### **MSB**

Most significant bit or byte, leftmost.

## O

## operators

The 12 mathematical functions in the assembler that designate the method, and implicitly the sequence, to be employed in combining terms or expressions. Evaluation of an expression begins with the substitution of values for each term. The operations are then performed from left to right in hierarchical order. The operation with the highest hierarchy number is performed first; operations with the same hierarchy number are performed from left to right.

Parentheses may be used to alter the order of evaluation. Multiplication by 0 equeals 0. The 12 operators are divided into three classes: arithmetic operators, logical operators, and relational operators.

## P

## privileged instructions

Instructions used by the operating system when the processor is in the supervisor state. If an application program (user program) attempts to execute a privileged instruction, a program exception interrupt will occur because the processor will be in the problem state. The following are the privileged instructions for the SPERRY UNIVAC Operating System/3 (OS/3).

- Diagnose (DIAG)
- Halt and proceed (HPR)
- Insert storage key (ISK)
- Load control storage (LCS)
- Load program status word (LPSW)
- Start I/O (SIO)
- Supervisor load multiple (SLM)
- SOFTSCOPE forward scan (SSFS)
- Set storage key (SSK)
- Set system mask (SSM)
- SOFTSCOPE reverse scan (SSRS)
- Supervisor store multiple (SSTM)
- Service timer register (STR)

#### program status word (PSW)

A special register containing information on the status of the program being run. The PSW contains the condition code, interrupt code, and the address of the next executable instruction. See status switching instructions.

## **PSW**

See program status word.

## relational operators

The equals symbol (=), the greater than symbol (>), and the less than symbol (<).

The equals operator is used to compare the value of two terms or expressions. If the two values are equal, the assembler assigns a value of 1 to the expression; otherwise, a value of 0 is assigned.

The greater than operator makes a comparison between two terms or expressions. If the value of the first (left) term is greater than the value of the second (right) term, then a value of 1 is assigned to the expression; otherwise, a value of 0 is assigned.

The less than operator compares the value of the first (left) expression or term with the second (right) expression. If the value of the first expression is less than the value of the second one, then a value of 1 is assigned to the expression; otherwise, a value of 0 is assigned.

For the expression A+B>C, if the expression A+B has a value greater than a value of C, then the assembler assigns a value of 1 to the expression; otherwise, a value of 0 is assigned.

A relational expression consists of a relational operator and its two operands. The operands in a relational expression may be either two character expressions or two arithmetic expressions. A character expression may not be compared to an arithmetic expression. Character expressions are valid only on conditional assembly directives.

Since the evaluation of a relational expression yields an arithmetic result, a relational expression may be used as a term in an arithmetic expression.

#### relocatability attributes

Values that are assigned to symbols defined in the label field of a source code line representing an instruction, constant, or storage definition. A relocatable symbol is a symbol whose address would change by a given number of bytes if the program in which it appears is relocated the same number of bytes from its originally assigned address. Relocatable symbols are assigned values relative to the location counter. Decimal, character, binary, and hexadecimal representations are all absolute terms and have a relocation attribute of O.

#### relocatable expressions

An expression whose value changes with program relocation. All relocatable expressions must be positive values.

Relocatable terms alone or relocatable terms in combination with absolute terms can be contained within a relocatable expression.

Either type of relocatable expression requires the following conditions:

- All but one relocatable term must be paired.
- A minus sign must not precede the unpaired (remaining) relocatable term.

- Each pair of relocatable terms must have opposite signs and the same relocatability attribute.
- The paired relocatable terms do not have to be contiguous.

Using the above requirements, a relocatable expression is thereby reduced to a single relocatable term. The following are relocatable expressions:

```
R
R/I
R+A or A+R
R—R+R
R—A
R*I or I*R

where:

A
Is an absolute term.
```

## reproduce following record (REPRO)

Is a relocatable term.

The directive used to reproduce a record in the assembler output.

## S

#### SDT

See self-defining terms.

## self-defining terms (SDT)

Terms that represent fixed values. They are presented by the programmer in a form that is easily recognized and its value is understood without the need for computation. SDTs are not relocatable; they can be used to specify immediate data, registers, addresses, and masks. They can be used in assembler directives as well as in application instructions and can be part of an expression. The size of an SDT depends on where it is used. When used to designate a register, it cannot exceed a value of 15. After conversion by the assembler to a binary format, the value is right-justified and filled with binary zeros on the left to fit the designated field. SDTs can be represented in binary, hexadecimal, decimal, or character form.

When a 24-bit hexadecimal, binary, or character SDT has a 1 in the sign bit position, the SDT will be treated as a negative term in the evaluation of an arithmetic expression.

- A binary SDT consists of a series of 24 zeros and ones enclosed in apostrophes and preceded by the letter B (e.g., B'101',B'11110000',B'00101'). The field is filled with high order zeros when necessary.
- A hexadecimal SDT consists of up to six hexadecimal digits enclosed in apostrophes and preceded by the letter X (e.g., X'F0',X'C1',X'F1F0F0'). Each hexadecimal digit represents a half byte of information.

PAGE

- A decimal SDT is an unsigned decimal number consisting of up to eight digits having a value of 0 through 16,777,215 (2<sup>24</sup>—1) (e.g., 0, 32, 16000000). This number is converted by the assembler to a binary value occupying one, two, or three bytes.
- A character SDT consists of up to 3 characters of the 256 valid characters of which only 63 are printable. The characters must be enclosed in apostrophes and preceded by the letter C (e.g., C'A', C'ABC', C'123', C'A1'). Each ampersand or apostrophe to be included in a character representation must be indicated by a double ampersand or double apostrophe respectively. In this case, there may be more than three characters within the apostrophes that delimit the SDT (e.g., C'3"S' produces 3'S; C'A&&B' produces A&B).

#### set symbol

A type of variable symbol. The rules for writing set symbols are the same as for other variable symbols:

- An ampersand (&) is followed by an alphabetic character followed by up to six additional characters (total maximum characters: eight)
- If the ampersand is omitted, the assembler interprets the character string as a symbol and not as a set symbol.

Because set symbols are evaluated in the macro generation phase of the assembler, they may be used as counters, switches, or values to control the sequence of code generated. Unlike an ordinary symbol, the value assigned to a set symbol may be altered during assembly. A set symbol may be either global or local. A global set symbol, once declared and given a value by a SET statement, retains the same value until that value is changed by another SET statement. A local set symbol is defined only within the macro definition in which it is declared. The value of a local set symbol within one macro definition is not affected by the declaration of either a global or local set symbol with the same name in another macro definition.

Do not use &SYS as the first four characters of any symbol because they are reserved for the use of system variable symbols.

Set symbols must be declared after macro prototype or NAME statements and before being referenced.

Four statements are provided to assign values to set symbols: SETA, SETB, SETC, and SET. The statement used depends on the statement chosen to declare the set symbol.

**SETA** 

Assigns values to set symbols declared in either LCLA or GBLA.

**SETB** 

Assigns values to set symbols declared in either LCLB or GBLB.

SETC

Assigns values to set symbols declared in either LCLC or GBLC.

SET

Assigns values to set symbols declared in either LCL or GBL.

The 14 special characters that are not part of the alphabetic set, are not special letters, and are not numerals. The special characters with their hexadecimal codes are:

| Special<br>Character | Hexadecimal<br>(EBCDIC) Code | Special<br>Character  | Hexadecimal (EBCDIC) Code |  |  |
|----------------------|------------------------------|-----------------------|---------------------------|--|--|
| +                    | 4E                           | ( left<br>parenthesis | 4D                        |  |  |
| - (minus)            | 60                           | ) right parenthesis   | 5D                        |  |  |
| *                    | 5C                           | . (period)            | 48                        |  |  |
| /                    | 61                           | &                     | 50                        |  |  |
| , (comma)            | 6B                           | ' (prime)             | 7D                        |  |  |
| =                    | 7E                           | >                     | 6E                        |  |  |
| $\triangle$ (blank)  | 40                           | <                     | 4C                        |  |  |
|                      | <u> </u>                     | i I                   |                           |  |  |

## special letters

The four special letters are:

| Special Letters | Hexadecimal<br>(EBCDIC) Code |
|-----------------|------------------------------|
| ?               | 6F                           |
| \$              | 5B                           |
| #               | 7B                           |
| @               | 7C                           |

## specify location counter (ORG)

The directive that sets or resets the location counter to a specified value.

## status switching instructions

The instructions that provide the capability of altering processor operating characteristics. The *set program* mask (SPM) and *supervisor call* (SVC) instructions replace part of the current program status word (PSW).

The format of the PSW is:

|   | SYSTEM MASK      |                       |                       |                       |       |           |   | KEY | ,  |    | •      |        | МО        | DE |    |             |    |    |    | INTERRUPT<br>CODE |
|---|------------------|-----------------------|-----------------------|-----------------------|-------|-----------|---|-----|----|----|--------|--------|-----------|----|----|-------------|----|----|----|-------------------|
| т | 1<br>0<br>S<br>T | S<br>P<br>A<br>R<br>E | S<br>P<br>A<br>R<br>E | S<br>P<br>A<br>R<br>E | SPARE | S P A R E |   |     |    | A  | P<br>R | P<br>S | S P A R E | М  |    | M<br>O<br>N |    |    |    |                   |
| 0 | 1                | 2                     | 3                     | 4                     | 5     | 6         | 7 | 8   | 11 | 12 | 13     | 14     | 15        | 16 | 18 | 19          | 20 | 23 | 24 | 3                 |

|        | PROC<br>MA | SRA | М  |    |    | INSTRUCTION ADDRESS |
|--------|------------|-----|----|----|----|---------------------|
| ILC CC |            | В   | D  | E  | s  |                     |
| 32 33  | 34 35      | 36  | 37 | 38 | 39 | 40 63               |

For information on the format, description, and use of the PSW, see the processor programmer reference, UP-8052 (current version).

The test and set (TS) instruction is used to control a byte in main storage to act as an indicator.

## symbols

Identifications appearing in the label field of a statement defining an instruction, constant, or storage area that are assigned the address value of the first byte of the source statement with which the symbol is associated. The following rules apply to the use of symbols used as labels.

- Must start in column 1
- Must start with an alphabetic character or special letter
- Must consist of only alphabetic characters, numeric characters, and special letters.
- Must not be longer than eight characters.
- Must not include a space (blank) or other special character
- Must be followed by a blank

The assembler associates three attributes with each symbol it processes. These attributes are value, length, and relocatability. Symbols defined by the EQU directive adopt the attributes of the expression in the operand field of the statement.

Once symbols are defined in the label field, they can be used as operands to represent the value which was defined.

## T

## terms

Values coded by the programmer or computed by the assembler. There are five classes of terms recognized by the assembler.

- Self-defining terms (SDT)
- Literals
- Symbols
- Location counter references
- Length attribute references

Self-defining terms are fixed values the programmer codes, such as 33,P'591',X'OF',B'11100110', or C'EBW'. Literals can have their value specified by the programmer or computed by the assembler and could look like =X'FO',=C'A', =P'—1', or =B'00001000' as used in storage-to-storage instructions (e.g., CLC TAGA,=C'A'). Symbols, location counter references, and length attribute references are assigned values by the assembler.

## U

## unassign base register (DROP)

The directive that informs the assembler specified registers are no longer available for base register assignment.

## unconditional branch (AGO)

The statement that unconditionally alters the sequence of source statement processing.



#### value attribute

The value assigned a symbol when it appears in the label field of any source code statement other than a comment. A symbol appearing in the label field of an EQU or ORG directive is assigned the value of the expression in the operand field. In all other cases, the value assigned is the current value of the location counter after the adjustment to a half-word, full-word, or double-word boundary, if necessary. The value is assigned to the current label before the location counter is incremented for the next instruction, constant, or storage definition. Thus, if a symbol appears in the label field of a statement defining an instruction, constant, or storage area, the symbol is assigned a value equal to the storage area address of that instruction, constant, or storage area.

The value of a symbol must lie in the range  $-2^{23}$  through  $2^{23}-1$ .

## variable symbol

A symbol consisting of two to eight characters; the first is an ampersand (&), the second is a letter (A through Z) or a special character (? \$ # @), and each of the remaining characters is a letter, special character, or digit (O through 9).

A variable symbol may be:

- a symbolic parameter;
- a set symbol;
- the label of a DO statement; or
- a system variable symbol.

Variable symbol symbolic parameters represent either the label or one of the operands of the macro instruction by which the macro definition was named.

The following rules apply to the use of variable symbols:

 A variable symbol may not be used to generate a new sequence symbol, a SET symbol, a parameter, or a system variable symbol.  A variable symbol may not be used in the label or operand field of an END, ICTL, ISEQ, COPY, or PRINT directive.

- No variable symbol replacement is performed on the line following a REPRO directive.
- Variable symbol replacement must not produce leading blanks in the label or operand fields.

A variable symbol may appear in a statement concatenated (joined) with other variable symbols or characters. If a variable symbol is immediately followed by a letter, digit, left parenthesis, or period, a period must be written after the variable symbol to distinguish the variable symbol from the characters that follow it. The variable symbol and the period following it are replaced by the characters representing the value of the variable symbol. The period does not appear in the printed statement. If a period is between a character string (not in quotes) and a variable symbol (in that order), the period is considered part of the character string and will appear in the printed statement.

The period after the variable symbol is optional if the variable symbol terminates with a right parenthesis or is followed by another variable symbol or a special character other than a left parenthesis or a period.



## **USER COMMENT SHEET**

Your comments concerning this document will be welcomed by Sperry Univac for use in improving subsequent editions.

Please note: This form is not intended to be used as an order blank. (Document Title) (Document No.) (Revision No.) (Update No.) Comments: From: (Name of User) (Business Address)

ut along line.

FOLD

**FOLD** 



# 12 "ET

NO POSTAGE NECESSARY IF MAILED IN THE UNITED STATES

# **BUSINESS REPLY MAIL**

FIRST CLASS

PERMIT NO. 21

BLUE BELL, PA.

POSTAGE WILL BE PAID BY ADDRESSEE

SPERRY UNIVAC

ATTN.: SYSTEMS PUBLICATIONS

P.O. BOX 500 BLUE BELL, PENNSYLVANIA 19424 S