## Operating System/3 (OS/3)

## Assembler

## User Guide

This Library Memo announces the release and availability of "SPERRY UNIVAC ${ }^{\circledR}$ ( Operating System/3 (OS/3) Assembler User Guide", UP-8061 Rev. 3.

This revision provides the 8.0 release enhancements to the OS/3 Assembler. The enhancements include:

- An additional UPSI byte setting for diagnostic errors.
- The addition of STXIT island code (providing the capacity to continue job streams when program checks occur).
- The display of error messages on the console.
- An additional warning message when using continuation characters with macroinstructions. (A comma after the last operand is checked.)

Appendix A was also expanded to include the job control to execute the sample program. In addition, other technical changes were made throughout the document.

Destruction Notice: If you are going to $\mathrm{OS} / 3$ release 8.0, use this revision and destroy all previous copies. If you are not going to $0 S / 3$ release 8.0 , retain the copy you are now using and store this revision for future use.

Copies of UP-8061 Rev. 2, UP-8061 Rev. 2-A, UP-8061 Rev. 2-B and UP-8061 Rev. 2-C will be available for 6 months after the release of 8.0 . Should you need additional copies of this edition, 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.

Mailing Lists
$B Z, C Z$ and $M Z$

LBRARY MEMO AND ATTACHMENIS

Mailing Lists $A 00, A 18,18,18 U, 19,19 U, 20,20 U, 21,21 U, 75$, 75U,76 and 76U
(Cover and 710 pages)

ThIS SHEETIS

Library Memo for UP-8061 Rev. 3

Assembler


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
ISSUE: UP-8061 Rev. 3
RELEASE LEVEL: 8.0 Forward

| Part/Section | Page Number | Update Level |
| :---: | :---: | :---: |
| Cover/Disclaimer |  |  |
| PSS | 1 |  |
| Preface | 1, 2 |  |
| Contents | 1 thru 17 |  |
| PART 1 | Title Page |  |
| 1 | 1 thru 19 |  |
| 2 | 1 thru 10 |  |
| 3 | 1 thru 3 |  |
| 4 | 1 thru 19 |  |
| PART 2 | Title Page |  |
| 5 | 1 thru 19 |  |
| 6 | 1 thru 4 |  |
| PART 3 | Title Page |  |
| 7 | 1 thru 6 |  |
| 8 | 1 thru 19 |  |
| 9 | 1 thru 52 |  |
| 10 | 1 thru 63 |  |
| 11 | 1 thru 94 |  |
| 12 | 1 thru 72 |  |
| 13 | 1 thru 20 |  |
| 14 | 1 thru 53 |  |
| PART 4 | Title Page |  |
| 15 | 1 |  |
| 16 | 1 thru 3 |  |
| 17 | 1 thru 8 |  |
| 18 | 1 thru 4 |  |


| Part/Section | Page Number | Update Level |
| :---: | :---: | :---: |
| 19 | 1 thru 13 |  |
| 20 | 1 thru 6 |  |
| 21 | 1 thru 9 |  |
| PART 5 | Title Page |  |
| 22 | 1 thru 4 |  |
| 23 | 1 thru 10 |  |
| 24 | 1 thru 11 |  |
| 25 | 1 thru 11 |  |
| 26 | 1 thru 7 |  |
| 27 | 1 thru 30 |  |
| PART 6 | Title Page |  |
| 28 | 1 thru 5 |  |
| PART 7 | Title Page |  |
| 29 | 1 thru 21 |  |
| 30 | 1 thru 5 |  |
| PART 8 | Title Page |  |
| Appendix A | 1 thru 4 |  |
| Appendix B | 1 thru 7 |  |
| Appendix C | 1 thru 9 |  |
| Appendix D | 1 thru 3 |  |
| Appendix E | 1 thru 15 |  |
| Appendix F | 1 thru 8 |  |
| Appendix G | 1 thru 5 |  |
| Index | 1 thru 28 |  |
| User Comment Sheet |  |  |
|  |  |  |


| Part/Section | Page <br> Number | Update Level |
| :---: | :---: | :---: |
|  |  |  |
|  |  |  |
|  |  |  |
|  |  |  |
|  |  |  |
|  |  |  |
|  |  |  |
|  |  |  |
|  |  |  |
|  |  |  |
|  |  |  |
|  |  |  |
|  |  |  |
|  |  |  |
|  |  |  |
|  |  |  |
|  |  |  |
|  |  |  |
|  |  |  |
|  |  |  |
|  |  |  |
|  |  |  |
|  |  |  |
|  |  |  |
|  |  |  |
|  |  |  |
|  |  |  |
|  |  |  |
|  |  |  |
|  |  |  |
|  |  |  |
|  |  |  |
|  |  |  |
|  |  |  |
|  |  |  |
|  |  |  |
|  |  |  |
|  |  |  |
|  |  |  |

Al/ the technical changes are denoted by an arrow ( $\rightarrow$ ) in the margin. A downward pointing arrow ( $\dagger$ ) next to a line indicates that technical changes begin at this line and continue until an upward pointing arrow ( 41 is found. A horizontal arrow ( $\rightarrow$ ) pointing to a line indicates a technical change in only that line. A horizontal arrow located between two consecutive lines indicates technical changes in both lines or deletions.
$\bullet$

## Preface

This manual is one of a series designed to instruct and guide the programmer in the use of the SPERRY UNIVAC Operating System/3 (OS/3). This manual specifically describes the OS/3 assembler and its effective use. Its intended audience is the novice programmer with a basic knowledge of data processing, but with limited programming experience, and the assembler programmer whose experience is limited to non-UNIVAC systems.

Two other manuals are available that cover OS/3 assembler; one is an introductory manual and the other is a programmer reference. The introductory manual briefly describes OS/3 assembler and its facilities. The programmer reference provides the characteristics of $\mathrm{OS} / 3$ assembler in skeletal form and is intended as a quick-reference document for the programmer experienced in the use of $\mathrm{OS} / 3$ assembler.

This user guide is divided into the following parts:

## - PART 1. BASIC DATA AND CONVENTIONS

Introduces you to what basic assembly language (BAL) is, how the computer stores information (data), how to locate the data required, and what forms mathematic notations assume in computer manipulations. The general rules that a programmer must understand to solve simple BAL problems are stated in this part. Where the content may seem out of context to the more experienced user, he can find such material repeated in greater detail in the following parts of this manual. As the manual progresses, the problems and examples become increasingly complex.

- PART 2. STORAGE AND SYMBOL DEFINITIONS

Describes and illustrates the use of storage assignments, the constants, and the rules for symbol designations.

- PART 3. BAL APPLICATION INSTRUCTIONS

Presents the explicit and implicit formats for all the assembly language application instructions, the rules of their use and illustrative examples.

- PART 4. BAL DIRECTIVES

Describes and illustrates the use of all the assembler control directives.

- PART 5. BAL MACROS

Explains the macro facility for writing and using this time-saving feature of the assembler.

- PART 6. ASSEMBLY LISTING

Describes what an assembly listing is, what it means, and how it is of use to the programmer.

- PART 7. PROGRAMMING TECHNIQUES

A series of programming techniques are presented in this part.

- PART 8. APPENDIXES

The appendixes contain figures and tables for use in explaining the text and for general programmer reference.

Each of the foregoing parts consists of one or more sections that cover the different aspects of the subject matter covered in each part.

## Contents

## PAGE STATUS SUMMARY

## PREFACE

## CONTENTS

## PART 1. BASIC DATA AND CONVENTIONS

## 1. INTRODUCTION TO ASSEMBLER LANGUAGE PROGRAMMING

### 1.1. CODING AN ASSEMBLER PROGRAM <br> 1-1

1.1.1. Operation Field

1-4
1.1.2. Operand Field

1-5
1.1.3. Label Field

1-6
1.1.4. Comments Field

1-8
1.1.5. Sequence Numbers $\quad 1-9$
1.1.6. Column 72

1-10
1.1.7. Additional Coding Rules

1-10
1.2. ASSEMBLING A PROGRAM 1-12
1.3. CREATING A LOAD MODULE $1-16$
1.4. PROGRAM EXECUTION 1-17
2. DATA FORMS
2.1. DATA REPRESENTATION 2-1
2.2. BINARY REPRESENTATION 2-2
2.3. HEXADECIMAL REPRESENTATION 2-3
2.4. CHARACTER REPRESENTATION ..... 2-5
2.4.1. Alphabetic Characters ..... 2-5
2.4.2. Special Letters ..... 2-6
2.4.3. Numeric ..... 2-6
2.4.3.1. Unpacked Format ..... 2-6
2.4.3.2. Packed Format ..... 2-7
2.4.4. Special Characters ..... 2-8
2.5. FIXED-POINT NUMBERS ..... 2-9
2.6. FLOATING-POINT NUMBERS ..... 2-9
3. ADDRESSING
3.1. MAIN COMPUTER STORAGE ADDRESSING ..... 3-1
3.1.1. Instruction Addressing ..... 3-1
3.1.2. Data Field Addressing ..... 3-2
3.2. REGISTER ADDRESSING ..... 3-3
4. RULES AND CONVENTIONS
4.1. READING INSTRUCTION NOTATION ..... 4-1
4.1.1. Assembler Application Instruction Notations ..... 4-1
4.1.2. Notation Rules and Meanings ..... 4-4
4.2. TERMS ..... 4-8
4.2.1. Self-Defining Terms (SDT) ..... 4-9
4.2.2. Literals ..... 4-10
4.2.3. Symbols ..... 4-11
4.2.4. Location Counter References ..... 4-12
4.2.5. Length Attribute Reference ..... 4-13
4.3. OPERATORS ..... 4-13
4.3.1. Arithmetic Operators ..... 4-14
4.3.2. Logical Operators ..... 4-14
4.3.3. Relational Operators ..... 4-15
4.4. EXPRESSIONS ..... 4-15
4.4.1. Absolute Expressions ..... 4-16
4.4.2. Relocatable Expressions ..... 4-17
4.4.3. Complex Relocatable Expressions ..... 4-17
4.4.4. Character Expressions ..... 4-18
4.4.5. Length Attribute of Expressions ..... 4-18
4.4.6. Character Strings ..... 4-18

## PART 2. STORAGE AND SYMBOL DEFINITIONS

## 5. STORAGE DEFINITIONS

5.1. STORAGE USAGE ..... 5-1
5.1.1. Define Constant ..... 5-4
5.1.2. Define Storage ..... 5-5
5.1.3. Duplication Factor ..... 5-5
5.1.4. Definition Type ..... 5-6
5.1.5. Length Factor ..... $\left(L_{n}\right)$ ..... 5-6
5.1.6. Constant Specification ..... 5-7
5.1.7. Alignment ..... 5-8
5.2. DEFINITION TYPES ..... 5-8
5.2.1. Character Constants ..... 5-8
5.2.2. Hexadecimal Constants ..... 5-9
5.2.3. Binary Constants ..... 5-9
5.2.4. Packed Decimal Constants ..... 5-10
5.2.5. Zoned Decimal Constants ..... 5-10
5.2.6. Half-Word Fixed-Point Constants ..... 5-11
5.2.7. Full-Word Fixed-Point Constants ..... 5-12
5.2.8. Half-Word Address Constants ..... 5-12
5.2.9. Full-Word Address Constants ..... 5-13
5.2.10. Base and Displacement Constants ..... 5-13
5.2.11. External Address Constants ..... 5-14
5.2.12. Floating-Point Constants5-15
5.3. LITERALS ..... 5-18
6. SYMBOL DEFINITIONS
6.1. EQUIVALENT SYMBOLS ..... 6-2
6.2. SYMBOL APPLICATIONS ..... 6-3
PART 3. BAL APPLICATION INSTRUCTIONS
7. INTRODUCTION TO APPLICATION INSTRUCTIONS
7.1. INSTRUCTION AND FORMAT CONVENTIONS ..... 7-1
7.2. EXPLICIT FORMS ..... 7-5
7.3. IMPLICIT FORMS ..... 7-6
7.4. DEFINITIONS OF FORMAT TERMS ..... 7-6
8. BRANCHING INSTRUCTIONS
8.1. USE OF BRANCHING INSTRUCTIONS ..... 8-1
8.2. EXTENDED MNEMONIC CODES ..... 8-2
8.3. BRANCH AND STORE (BAS, BASR) ..... 8-5
8.4. BRANCH AND LINK (BAL, BALR) ..... 8-6
8.4.1. Use of the BALR Instruction in Base Register Assignment ..... 8-8
8.5. BRANCH ON CONDITION(BC, BCR)8-10
8.6. BRANCH ON COUNT(BCT, BCTR)8-148.7. EXECUTE(EX)8-16
9. DECIMAL AND LOGICAL INSTRUCTIONS
9.1. USING DECIMAL INSTRUCTIONS ..... 9-1
9.2. DEFINING PACKED AND UNPACKED CONSTANTS AND MAIN STORAGE AREAS ..... 9-3
9.2.1. Packed Decimal Constants and Main Storage Areas ..... 9-4
9.2.2. Unpacked Decimal Constants and Main Storage Areas ..... 9-6
9.3. ADD DECIMAL (AP) ..... 9-8
9.4. COMPARE DECIMAL (CP) ..... 9-10
9.5. DIVIDE DECIMAL (DP) ..... 9-12
9.6. EDIT (ED) ..... 9-15
9.6.1. The Edit Pattern ..... 9-16
9.6.2. The Resulting Condition Code ..... 9-22
9.6.3. Examples of General Usage ..... 9-23
9.6.4. Summary ..... 9-25
9.7. MOVE CHARACTER (MVC) ..... 9-26
9.8. MOVE NUMERICS (MVN) ..... 9-30
9.9. MOVE WITH OFFSET (MVO) ..... 9-33
9.10. MOVE ZONES (MVZ) ..... 9-36
9.11. MULTIPLY DECIMAL (MP) ..... 9-38
9.12. PACK DECIMAL (PACK) ..... 9-40
9.13. SUBTRACT DECIMAL ..... (SP) ..... 9-44
9.14. UNPACK DECIMAL (UNPK) ..... 9-47
9.15. ZERO AND ADD DECIMAL ..... 9-50

## 10. FIXED-POINT BINARY INSTRUCTIONS

| 10.1. | USE OF FIXED-POINT BINARY INSTRUCTIONS |  | 10-1 |
| :---: | :---: | :---: | :---: |
| 10.1.1. | Half-Word Fixed-Point Constants |  | 10-3 |
| 10.1.2. | Full-Word Fixed-Point Constants |  | 10-3 |
| 10.1.3. | Address Constants |  | 10-4 |
| 10.1.3.1. | Full-Word Address Constants |  | 10-4 |
| 10.1.3.2. | Half-Word Address Constants |  | 10-5 |
| 10.1.4. | Representation of Positive and Negative |  |  |
|  | Fixed-Point Binary Numbers |  | 10-5 |
| 10.2 | ADD | (A) | 10-7 |
| 10.3. | ADD | (AR) | 10-9 |
| 10.4. | ADD HALF WORD | (AH) | 10-11 |
| 10.5. | ADD IMMEDIATE | (AI) | 10-13 |
| 10.6. | COMPARE | (C) | 10-15 |
| 10.7. | COMPARE | (CR) | 10-17 |
| 10.8. | COMPARE HALF WORD | (CH) | 10-19 |
| 10.9. | CONVERT TO BINARY | (CVB) | 10-21 |
| 10.10. | CONVERT TO DECIMAL | (CVD) | 10-24 |
| 10.11. | DIVIDE | (D) | 10-27 |
| 10.12. | LOAD | (L) | 10-31 |
| 10.13. | LOAD | (LR) | 10-33 |
| 10.14. | LOAD AND TEST | (LTR) | 10-35 |
| 10.15. | LOAD HALF WORD | (LH) | 10-37 |
| 10.16. | LOAD MULTIPLE | (LM) | 10-39 |
| 10.17 | MULTIPLY | (M) | 10-45 |
| 10.18. | STORE | (ST) | 10-49 |
| 10.19. | STORE HALF WORD | (STH) | 10-51 |
| 10.20. | STORE MULTIPLE | (STM) | 10-53 |
| 10.21. | SUBTRACT | (S) | 10-56 |
| 10.22. | SUBTRACT | (SR) | 10-58 |
| 10.23. | SUBTRACT HALF WORD | (SH) | 10-61 |

## 11. FLOATING-POINT INSTRUCTIONS

11.1. INTRODUCTION
11.2. ADD NORMALIZED, LONG FORMAT
11.3. ADD NORMALIZED, LONG FORMAT
11.4. ADD NORMALIZED, SHORT FORMAT
11.5. ADD NORMALIZED, SHORT FORMAT
11.6. ADD UNNORMALIZED, SHORT FORMAT
11.7. ADD UNNORMALIZED, SHORT FORMAT
11.8. ADD UNNORMALIZED, LONG FORMAT
11.9. ADD UNNORMALIZED, LONG FORMAT
11.10. COMPARE, LONG FORMAT
11.11. COMPARE, LONG FORMAT
11.12. COMPARE, SHORT FORMAT
11.13. COMPARE, SHORT FORMAT
11.14. DIVIDE, LONG FORMAT
11.15. DIVIDE, LONG FORMAT
11.16. DIVIDE, SHORT FORMAT
11.17. DIVIDE, SHORT FORMAT
11.18. HALVE, LONG FORMAT
11.19. HALVE, SHORT FORMAT
11.20. LOAD COMPLEMENT, LONG FORMAT
11.21. LOAD COMPLEMENT, SHORT FORMAT
11.22. LOAD, LONG FORMAT
11.23. LOAD, LONG FORMAT
11.24. LOAD, SHORT FORMAT
11.25. LOAD, SHORT FORMAT
11.26. LOAD NEGATIVE, LONG FORMAT
11.27. LOAD NEGATIVE, SHORT FORMAT

| (AD) | $11-3$ |
| :--- | :---: |
| (ADR) | $11-6$ |
| (AE) | $11-9$ |
| (AER) | $11-12$ |
| (AU) | $11-15$ |
| (AUR) | $11-17$ |
| (AW) | $11-219$ |
| (AWR) | $11-23$ |
| (CD) | $11-25$ |
| (CDR) | $11-27$ |

(CER) 11-29
(DD) $11-31$
(DDR) 11-33
(DE) 11-35
(DER) 11-37
(HDR) 11-39
(HER) 11-41
(LCDR) 11-43
(LCER) 11 -45
(LD) 11-47
(LDR) 11-49
(LE) 11-51
(LER) 11-53
(LNDR) 11-55
(LNER) 11-57
11.28. LOAD POSITIVE, LONG FORMAT
11.29. LOAD POSITIVE, SHORT FORMAT
11.30. LOAD AND TEST, LONG FORMAT
11.31. LOAD AND TEST, SHORT FORMAT
11.32. MULTIPLY, LONG FORMAT
11.33. MULTIPLY, LONG FORMAT
11.34. MULTIPLY, SHORT FORMAT
11.35. MULTIPLY, SHORT FORMAT
11.36. SUBTRACT NORMALIZED, LONG FORMAT
11.37. SUBTRACT NORMALIZED, LONG FORMAT
11.38. SUBTRACT NORMALIZED, SHORT FORMAT
11.39. SUBTRACT NORMALIZED, SHORT FORMAT
11.40. STORE, LONG FORMAT
11.41. STORE, SHORT FORMAT
11.42. SUBTRACT UNNORMALIZED, SHORT FORMAT
11.43. SUBTRACT UNNORMALIZED, SHORT FORMAT
11.44. SUBTRACT UNNORMALIZED, LONG FORMAT
11.45. SUBTRACT UNNORMALIZED, LONG FORMAT
12. LOGICAL INSTRUCTIONS
12.1. THE USE OF LOGICAL INSTRUCTIONS
12.2. AND
(N)
(NC)
(NI) $\quad 12-8$
(NR)
(CL)
(CLC)
(CLI)
12.6. COMPARE LOGICAL
12.7. COMPARE LOGICAL CHARACTERS
12.8. COMPARE LOGICAL IMMEDIATE
(LPDR)
11-59
(LPER)
11-61
(LTDR)
(LTER)
(MD) 11-67
(MDR)
(ME)
(MER)
(SD) 11-75
(SDR) 11-77
(SE) 11-79
(SER)
(STD)
(STE)
(SU)
(SUR)
(SW)
(SWR)
11-93
12.3. AND
12.4. AND
12.5. AND

12-11
12-1

12-2

12-5

12-14
12-17
12-20

| 12.9. | COMPARE LOGICAL | (CLR) | $12-25$ |
| :--- | :--- | :--- | :--- |
| 12.10. | EXCLUSIVE OR | (X) | $12-27$ |
| 12.11. | EXCLUSIVE OR | (XC) | $12-30$ |
| 12.12. | EXCLUSIVE OR | (XI) | $12-33$ |
| 12.13. | EXCLUSIVE OR | (XR) | $12-36$ |
| 12.14. | INSERT CHARACTER | (IC) | $12-39$ |
| 12.15. | LOAD ADDRESS | (LA) | $12-41$ |
| 12.16. | MOVE IMMEDIATE | (MVI) | $12-43$ |
| 12.17. | OR | (O) | $12-45$ |
| 12.18. | OR | (OC) | $12-48$ |
| 12.19. | OR | (OI) | $12-51$ |
| 12.20. | OR | (OR) | $12-54$ |
| 12.21. | SHIFT LEFT SINGLE LOGICAL | (SLL) | $12-57$ |
| 12.22. | SHIFT RIGHT SINGLE LOGICAL | (SRL) | $12-60$ |
| 12.23. | STORE CHARACTER | (STC) | $12-62$ |
| 12.24. | TEST UNDER MASK | (TM) | $12-64$ |
| 12.25. | TRANSLATE | (TR) | $12-67$ |
| 12.26. | TRANSLATE AND TEST | (TRT) | $12-70$ |

## 13. PRIVILEGED AND STATUS SWITCHING INSTRUCTIONS

13.1. GENERAL ..... 13-113.2. STATUS-SWITCHING PRIVILEGED INSTRUCTIONS13-1
13.2.1. Halt and Proceed(HPR)13-2
13.2.2. Insert Storage Key(ISK)13-3
13.2.3. Load Control Storage
13.2.4. Load Program Status Word(LCS)13-4
13.2.5. Set Storage Key13.2.6. Set System Mask

13-5
(SSK)
13-6
(SSM)
13.3. INPUT/OUTPUT PRIVILEGED INSTRUCTION ..... 13-7
13.3.1. Start I/O (SIO) ..... 13-8
13.4. DIAGNOSTIC PRIVILEGED INSTRUCTIONS13.4.1. Diagnose13.4.2. SOFTSCOPE Forward Scan13.4.3. SOFTSCOPE Reverse Scan13.5. INTERNAL TIMER PRIVILEGED INSTRUCTION13-8

|  | $13-8$ |
| :--- | :--- |
| (DIAG) | $13-9$ |
| (SSFS) | $13-10$ |
| (SSRS) | $13-11$ |

13.5.1. Service Timer Register ..... (STR)
13-1113-12
13.6. GENERAL REGISTER PRIVILEGED INSTRUCTIONS

|  | $13-13$ |
| :--- | :--- |
| (SLM) | $13-13$ |
| (SSTM) | $13-14$ |

13.6.2. Supervisor Store Multiple Instruction(SSTM)13-14
13.7. SET PROGRAM MASK STATUS-SWITCHING INSTRUCTION
13.8. SUPERVISOR CALL STATUS-SWITCHING INSTRUCTION(SVC)
13-15
(SPM)13-17
13.9. TEST AND SET STATUS-SWITCHING INSTRUCTION(TS)13-19
14. FEATURED INSTRUCTIONS

| 14.1. | FEATURED BRANCHING INSTRUCTIONS |  | 14-1 |
| :---: | :---: | :---: | :---: |
| 14.1.1. | Branch on Index High | (BXH) | 14-2 |
| 14.1.2. | Branch on Index Low or Equal | (BXLE) | 14-5 |
| 14.2 | FEATURED FIXED-POINT INSTRUCTIONS |  | 14-6 |
| 14.2.1. | Divide | (DR) | 14-7 |
| 14.2.2. | Load Complement | (LCR) | 14-9 |
| 14.2.3. | Load Negative | (LNR) | 14-11 |
| 14.2.4. | Load Positive | (LPR) | 14-14 |
| 14.2.5. | Multiply | (MR) | 14-17 |
| 14.2.6. | Multiply Half Word | (MH) | 14-19 |
| 14.2.7. | Shift Left Double | (SLDA) | 14-22 |
| 14.2.8. | Shift Left Single | (SLA) | 14-25 |
| 14.2.9. | Shift Right Double | (SRDA) | 14-28 |
| 14.2.10. | Shift Right Single | (SRA) | 14-31 |
| 14.3. | FEATURED LOGICAL INSTRUCTIONS |  | 14-33 |
| 14.3.1. | Add Logical | (AL) | 14-34 |
| 14.3.2. | Add Logical | (ALR) | 14-37 |
| 14.3.3. | Edit and Mark | (EDMK) | 14-39 |
| 14.3.4. | Shift Left Double Logical | (SLDL) | 14-42 |
| 14.3.5. | Shift Right Double Logical | (SRDL) | 14-45 |
| 14.3.6. | Subtract Logical | (SL) | 14-48 |
| 14.3.7. | Subtract Logical | (SLR) | 14-51 |

PART 4. BAL DIRECTIVES
15. INTRODUCTION TO DIRECTIVES
16. EQUATE AND DELETE OPERATION CODE DIRECTIVES
16.1. EQUATE
16.2. DELETE OPERATION CODE
17. ASSEMBLER CONTROL DIRECTIVES
17.1. CONDITION NO OPERATION
17.2. PROGRAM END
17.3. GENERATE LITERALS
17.4. SPECIFY LOCATION COUNTER
17.5. PROGRAM START
18. BASE REGISTER ASSIGNMENT DIRECTIVES
18.1. UNASSIGN BASE REGISTER
18.2. ASSIGN BASE REGISTER
19. PROGRAM LINKING AND SECTIONING DIRECTIVES
19.1. COMMON STORAGE DEFINITION
19.2. CONTROL SECTION IDENTIFICATION
19.3. DUMMY CONTROL SECTION IDENTIFICATION
19.4. EXTERNALLY REFERENCED SYMBOL DECLARATION
19.5. EXTERNALLY DEFINED SYMBOL DECLARATION
19.6. SUBROUTINE LINKAGE
(EQU)
16-1
(OPSYM)
16-3
(CNOP) 17-2
(END)
17-4
(LTORG)
17-5
(ORG)
(START)
(DROP)
(USING)
18-3
(COM)
(CSECT)
(DSECT)
19-7
(ENTRY)
19-9
(EXTRN)
19-10

## 20. LISTING CONTROL DIRECTIVES

20.1. ADVANCE LISTING
20.2. LISTING CONTENT CONTROL
20.3. LEAVE BLANK LINES ON LISTING
20.4. LISTING TITLE DECLARATION
21. INPUT AND OUTPUT CONTROL DIRECTIVES
21.1. INPUT FORMAT CONTROL
21.2. INPUT SEQUENCE CONTROL
21.3. REPRODUCE FOLLOWING RECORD
21.4. PRODUCE A RECORD
21.5. INCLUDE CODE FROM A LIBRARY
21.6. CHANNEL COMMAND WORD

PART 5. BAL MACROS

## 22. MACRO FACILITY

22.1. THE MACRO PROCESSOR 22-1
22.2. MACRO SOURCE CODE

22-3
23. MACRO DESIGN
23.1. THE MACRO DEFINITION 23-1
23.2. MACRO DEFINITION STORAGE

23-3
23.3. THE MACRO CALL INSTRUCTION

23-6
24. TWO TYPES OF MACRO DEFINITIONS
24.1. PROCS AND MACROS 24-1
24.2. CALL INSTRUCTION DESIGN
24.3. PASSING PARAMETERS TO THE BODY

## 25. PROC FORMAT

25.1. BASIC PROC DESIGN ..... 25-1
25.2. REFERENCING POSITIONAL PARAMETERS IN THE CALL ..... 25-3
25.3. REFERENCING KEYWORD PARAMETERS IN THE CALL ..... 25-4
25.4. REFERENCING SUBPARAMETERS IN THE CALL ..... 25-7
25.5. MULTIPLE PROC NAMES AND POSITIONAL PARAMETER 0 ..... 25-9
25.6. THE LABEL ARGUMENT ..... 25-11
26. MACRO FORMAT
26.1. BASIC MACRO DESIGN ..... 26-1
26.2. REFERENCING POSITIONAL PARAMETERS IN THE CALL ..... 26-2
26.3. REFERENCING KEYWORD PARAMETERS IN THE CALL ..... 26-4
26.4. REFERENCING SUBPARAMETERS IN THE CALL ..... 26-5
26.5. THE LABEL ARGUMENT ..... 26-6
27. CONDITIONAL ASSEMBLY
27.1. SET SYMBOLS ..... 27-2
27.1.1. Local Set Symbols ..... 27-3
27.1.2. Global Set Symbols ..... 27-4
27.1.3. Set Symbol Value Assignment ..... 27-6
27.1.4. SET Statement ..... 27-6
27.1.5. SETA Statement ..... 27-9
27.1.6. SETB Statement ..... 27-10
27.1.7. SETC Statement ..... 27-12
27.1.8. Character Expressions ..... 27-13
27.1.9. Subscripted SET Symbols ..... 27-13
27.1.9.1. Defining Subscripted SET Symbols ..... 27-14
27.2. BRANCHING ..... 27-14
27.2.1. Sequence Symbols ..... 27-14
27.2.2. Unconditional Branch (AGO) ..... 27-15
27.2.3. Conditional Branch
27.2.4. Define Branch Destination
27.2.5. Macro Definition Exit(ANOP)27-17
(MEXIT) ..... 27-18
27.3. ERROR MESSAGES AND COMMENTS ..... 27-18
27.3.1. MNOTE Message Statements (MNOTE) ..... 27-1927.3.2. PNOTE Message Statements
(PNOTE) ..... 27-20
27.3.3. Comments Statement ..... 27-20
27.4. REPETITIVE CODE GENERATION ..... 27-21
27.4.1. Define Start of Range (DO) ..... 27-21
27.4.2. Define End of Range(ENDO)27-22
27.4.3. Conditional Assembly Control Counter (ACTR) ..... 27-23
27.5. ATTRIBUTE REFERENCES ..... 27-23
27.5.1. Type Attributes ..... 27-25
27.5.2. Length Attributes ..... 27-27
27.5.3. Scale Attributes ..... 27-28
27.5.4. Integer Attributes ..... 27-28
27.5.5. Count Attributes ..... 27-29
27.5.6. Number Attributes ..... 27-30
PART 6. ASSEMBLY LISTING
28. ORGANIZATION OF LISTING
28.1. HEADER LINES ..... 28-1
28.2. PREFACE ..... 28-1
28.3. CODEDIT ..... 28-2
28.4. EXTERNAL SYMBOL DICTIONARY LISTING ..... 28-3
28.5. CROSS-REFERENCE LISTING ..... 28-4
28.6. DIAGNOSTIC LISTING ..... 28-5
28.7. EXAMPLE OF ASSEMBLY LISTING ..... 28-5
PART 7. PROGRAMMING TECHNIQUES
29. JOB CONTROL PROCEDURES
29.1. HOW TO RUN A JOB ..... 29-1
29.2. INTRODUCING THE SOURCE DECK ..... 29-1
29.2.1. JOB Control Statement ..... 29-2
29.2.2. OPTION Job Control Statement ..... 29-2
29.3. ASSEMBLE; ASSEMBLE AND LINK-EDIT; OR ASSEMBLE LINK-EDIT AND EXECUTE ..... 29-3
29.3.1. Assemble (ASM) ..... 29-3
29.3.1.1. ASM Jproc Call Statement ..... 29-4
29.3.2. Assemble and Link-Edit (ASML) ..... 29-11
29.3.2.1. ASML Jproc Call Statement ..... 29-12
29.3.3. Assemble, Link-Edit, and Execute (ASMLG) ..... 29-13
29.3.3.1. ASMLG Jproc Call Statement ..... 29-14
29.4. START-OF-DATA JOB CONTROL STATEMENT (/\$) ..... 29-15
29.5. FOLLOWING THE SOURCE DECK ..... 29-15
29.5.1. End-of-Data Job Control Statement (/*) ..... 29-15
29.5.2. End-of-Job Control Statement (/\&) ..... 29-16
29.5.3. Terminate-the-Card-Reader Job Control Statement (// FIN) ..... 29-16
29.5.4. Setting the UPSI Byte ..... 29-16
29.6. SUMMARY OF JOB CONTROL PROCEDURE ..... 29-17
29.6.1. Assembly ..... 29-17
29.6.2. Assembly and Link-Edit ..... 29-19
29.6.3. Assembly, Link-Edit, and Execution ..... 29-21
30. EXAMPLE MACRO DEFINITIONS
30.1. SMALR/LARGR PROC (POSITIONAL PARAMTER 0) ..... 30-1
30.2. SMALL6/LARGE6 PROC (DO LOOP) ..... 30-2
30.3. BLANK MACRO (VARIABLE INLINE EXPANSION CODE) ..... 30-4
PART 8. APPENDIXES
A. SAMPLE PROGRAM
B. CHARACTER CONVERSION CODES
C. MATH TABLES
C.1. HEXADECIMAL-DECIMAL INTEGER CONVERSION ..... C-1
C.2. HEXADECIMAL FRACTIONS (APPROXIMATE VALUES) ..... C-7
C.3. POWERS OF 2 ..... C-8
C.4. POWERS OF 16 ..... C-9
D. CHECK-OFF TABLE TERMS

## E. INSTRUCTION LISTINGS

## F. USE OF PARAM STATEMENT

## F.1. PARAM STATEMENT <br> F-1

F.2. SOURCE CORRECTIONS

F-5
F.2.1. SEQ Statement F-6
F.2.2. REC Statement F-7
F.2.3. SKI Statement F-7
G. SYSTEM VARIABLE SYMBOLS
G.1. \&SYSECT G-1
G.2. \&SYSLIST G-1
G.3. \&SYSNDX G-2
G.4. \&SYSDATE G-2
G.5. \&SYSTIME G-3
G.6. \&SYSJDATE G-4
G.7. \&SYSPARM G-4

USER COMMENT SHEET

FIGURES

1-1. Writing and Submitting a Program 1-1
1-2. Punched Card 1-2
1-3 Assembler Coding Form 1-3
1-4. Coding Form and Punched Card Relationship 1-4
1-5. Example of Proper Coding Techniques 1-11
1-6. COBOL Source Code 1-13
1-7. Object Code Generated from COBOL Source Code 1-13
1-8. Assembly Listing 1-14
1-9. OS/3 Object Module Format $\quad$ 1-16
1-10. OS/3 Load Module Format 1-18
1-11. Assemble, Link, and Go Operation 1-19
2-1. Determining Binary Values 2-3
2-2. Fixed-Point Number Formats 2-9

4-1. Assembler Format Relationships 4-5
4-2. Byte and Word Structure 4-7
5-1. Floating-Point Number Formats ..... 5-16
7-1. Instruction Formats ..... 7-2
8-1. Program Status Word Diagram ..... 8-1
10-1. Comparison of Binary Numbers and Values Expressed in Powers of 2 ..... 10-5
22-1. Example of Inline Macro Expansion ..... 22-2
23-1. Accessing a Macro Definition Submitted in the Source Deck ..... 23-4
23-2. Accessing a Macro Definition Stored in a Library ..... 23-5
24-1. PROC and MACRO Heading ..... 24-1
24-2. PROC, MACRO, and Call Instruction Comparison ..... 24-6
24-3. Communication between Macro Instruction and Macro Definition ..... 24-8
24-4. Example MACRO and PROC Definitions ..... 24-11

## TABLES

2-1. Comparison of Numeric Expressions ..... 2-2
2-2. Hexadecimal Notation ..... 2-4
4-1. Comparison of Terms ..... 4-9
4-2. Summary of Operators ..... 4-13
5-1. Characteristics of Constant and Storage Definition Types ..... 5-2
5-2. Zero Duplication Area Examples ..... 5-6
8-1. Extended Mnemonics and Functions ..... 8-3
8-2. Operand 1 Mask Combinations ..... 8-11
8-3. Branch-on-Condition Instruction by Usage ..... 8-12
9-1. Edit Instruction Operation ..... 9-25
15-1. Assembler Directives ..... 15-1
17-1. Assembler Control Directives ..... 17-1
20-1. Listing Control Directives ..... 20-1
27-1. Conditional Assembly Language Statements ..... 27-1
27-2. Operator Priority ..... 27-8
27-3. Valid Attribute Reference Applications ..... 27-24
27-4. Type Attributes of Symbols ..... 27-25
28-1. CODEDIT Listing Content ..... 28-2
28-2. External Symbol Dictionary (ESD) Listing Content ..... 28-3
28-3. Cross-Reference Content ..... 28-4
28-4. Diagnostic Listing Content ..... 28-5
B-1. ASCII (American Standard Code for Information Interchange) Character Codes ..... B-1
B-2. EBCDIC (Extended Binary Coded Decimal Interchange Code) Character Codes ..... B-2
B-3. Punched Card, ASCII, and EBCDIC CodesB-3

E-1. Mnemonic List of Instructions E-1
E-2. Alphabetic Listing of Instructions
E-5
E-3. List of Instructions by Machine Code E-10

## PART 1. BASIC DATA AND CONVENTIONS

# 1. Introduction to Assembler Language Programming 

### 1.1. CODING AN ASSEMBLER PROGRAM

An assembler language program goes through several transformations before it is actually inside the computer and operating (Figure 1-1). The first change is from handwritten form to punched card form. This conversion takes code that is decipherable by people and changes it to data that can be processed by the computer. Although an assembler source program may exist on other media, such as disk or tape, the deck of cards is almost always the artifact of the basic assembly language (BAL) programmer. An assembler program is built with a punched card deck.


Figure 1-1. Writing and Submitting a Program

The punched card deck is a biform storage medium that is common to the programmer and the computer. It contains a copy of a computer program that can be interpreted by both man and machine. This is unlike your handwritten program, which can only be deciphered by you and is meaningless to a digital computer. The punched card is in a form that can be converted to computer data.

The data converter for the computer is the card reader. It is an electromechanical device designed to read information from punched cards by detecting the presence and absence of holes in a card. The card reader converts the holes punched in cards on a column-bycolumn basis to data that can be processed by the computer. Each column on a punched card is used to represent a single unit of information and the card reader converts each column to the character it represents.

A blank card is shown in Figure 1-2. From this figure, you can see that a card has 80 vertical columns (numbered at the bottom and near the top of the card) and each column has 12 punch positions called rows. Rows 0 through 9 are numbered on the card, and 12 and 11 are not numbered; the 12 position is at the top of the card, and the 11 position immediately follows it and is before the 0 row.


Figure 1-2. Punched Card

Different combinations of holes in a column represent different characters and numbers. For instance, each of the decimal numbers 0 through 9 are represented by the respective punch positions on a card. If a column has a hole punched only in row 0 , then the card reader detects a 0 . If a punch is only in row 1 , then the card reader detects a 1 , and so on through row 9 . Everything you code in assembly language is based on the 80 -column card.

The cards that make up an assembler language program are punched on a keypunch machine from code that is handwritten on an assembler coding form. (The Sperry Univac assembler coding form is shown in Figure 1-3.) Each line on the assembler coding form has 80 positions that correspond to the 80 columns on a punched card. One card is keypunched for every line of code on the assembler coding form (Figure 1-4). The lines of code on the assembler coding form and the cards keypunched from the form are called source code lines. Collectively, these source lines make a source program.

A BAL source program is written with instructions, directives, conditional statements, and macros. They are the elements of the assembler language and each is usually written on one source line. (Sometimes it may take more than one source line to write a single element, but most of the time it takes only one source line for one instruction, directive, statement, or macro.) The assembler ignores the presence of any blank cards in the source deck. A blank line will not be printed nor terminate a sequence of continuation lines. The rules for coding assembler language source lines are reflected on the assembler coding form. Each source line has five fields and the assembler expects specific information to be coded in each field.



Figure 1-4. Coding Form and Punched Card Relationship

### 1.1.1. Operation Field

The easiest part of an assembler source code line to recognize is the operation field; it begins in column 10 and ends in column 14. The operation field is the most restrictive field on the coding form because you must use an established operation code. You cannot arbitrarily assign a name of your own. The operation code you use is a mnemonic code that relates to some function. For example, $A$ is for add, $D$ is for divide, and $S$ is for subtract. The mnemonic code must be written exactly as the instruction, directive, or statement indicates. For example, $A$ (not $A D$ ) causes the add operation to be performed. If you put $A D$ in the operation field, the assembler could not relate it to any of the assembler functions, so this would cause an error. Each mnemonic code for instructions, directives, statements, or macros is listed with the description of that function. The rules for using the operation 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 instructions, directives, statements, or macros.
3. The operation field must be terminated by a blank.
4. The operation code must not start in column 1.

## Examples:



### 1.1.2. Operand Field

The operand field is the object of the operation code. The operand field begins in column 16 and ends in column 71. The operand field holds the data or the location of data that is being operated on. Each item of data in the operand field is an operand, and operands are separated by commas. For instructions, operands can be actual data - like the decimal number 10, the name of an area where data is stored - like STORAREA, or the actual address specifying the number of bytes the assembler must count to get to the data - like $1108(32)$. Operands for instructions, directives, statements, or macros are whatever parameters are required by the particular operation that is being done. For instance, an add immediate instruction has two operands. The first operand is a main storage location, and the second operand is a byte of actual data. An add immediate instruction adds the second operand to whatever data is located at the first operand's address.

| LABEL | $\triangle O P E R A T I O N \triangle$ | OPERAND |
| :--- | :--- | :--- |
| 10 | 16 |  |

$$
\text { AI STORAREA, } 1 \varnothing
$$

The add operation in this example is performed on the actual data, 10, and on whatever data is located at an area named STORAREA.

The rules for using the operand field are:

1. The operand field is terminated by a blank that is not enclosed by an apostrophe.
2. Operands may be continued onto the next line by placing a nonblank character in column 72. Up to two continuation lines are permitted. Caution should be exercised when using a nonblank character in column 72. As shown in the OUTFILE DTFMT example (1.1.7), a comma must follow the last operand on the continued statement if there are more operands to follow; otherwise, the operands that follow will be treated as comments.
3. Column 16 is where a continuation line starts.

Examples:


1. Valid
2. Invalid because the operand field is not terminated by a blank
3. Invalid because the line has an embedded blank

### 1.1.3. Label Field

As we mentioned, the operand field can contain data or the name of an area where data is stored. You assign a name to an area in your program by coding a symbolic name in the label field of the area to be accessed. Once a source line is given a label, it can be referenced from any other location in the source program. For example, I can name a line of code and use its name in the operand field of an instruction.


In this example, I labeled an add instruction: ROUTINE. Then, later in my program, I used the symbol ROUTINE to refer to that line of code. On line 2, I said, "Branch to the area called ROUTINE, where the add instruction is located."

A symbol in the label field of a line of code can also be used as an operand to reference data. For example, I can write a line of code to define a constant.

| LABEL | $\triangle O P E R A T I O N \triangle$ |  | OPERAND |
| :---: | :---: | :---: | :---: |
| 1 | 10 | 16 |  |
| TEN | DC |  |  |

This line of code says, "Place the decimal number 10 in the location named TEN." Once the symbol TEN is defined, it can be used as an operand to represent the value 10.

AI
TEN, 6

In this line of coding, I'm requesting that 6 be added to whatever data is stored at location TEN. When you label data as I labeled the data (10), you are associating a symbol with a value. That symbol can then be used in place of the value.

The rules for using the label 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.

Examples:

```
LABEL \triangleOPERATION\triangle
OPERAND
llll
```

BEGIN
2.
BEGIN
WEEKS52
52WEEKS
EMPLOYEE
EMPLOYEENO
BLANKNO
blank NO
MOVEPAYMVCYEARPAY, WORK

1. Valid
2. Invalid because the symbol does not start in column 1
3. Valid
4. Invalid because the symbol starts with a number
5. Valid
6. Invalid because the symbol is longer than eight characters
7. Valid
8. Invalid because the symbol contains an embedded blank
9. Invalid because the symbol MOVEPAY is not followed by a blank (There must also be a blank after the operation code MVC.)

The three fields just discussed are essential for designing an executable BAL program. The remaining two fields, the comment and sequence fields, don't play a role in the actual design of a program but they are useful programming aids. The comment field is a program documentation aid and the sequence field is a program maintenance aid. Program documentation is as important to the programmer writing the program as it is to those who must refer to it later. Operand specification is usually completed by column 40, thus leaving columns 41 through 71 free for comments.

### 1.1.4. Comments Field

There are two ways to code comments:

1. Comments can be coded on the same line as an instruction, statement, or directive. There must be at least one blank between the end of the operand specification and the start of comments. If your comments exceed one source line, place a nonblank character in column 72 and continue the remaining comments on the next source line (at column 16).

Examples:

| LABEL | $\triangle O P E R A T I O N \triangle$ | OPERAND | $\triangle C O M M E N T S$ |
| :---: | :---: | :---: | :---: |


2. Comments can be coded on a separate line. This is done by placing an asterisk (*) in column 1 of a source line followed by at least one blank space. Then your comments can be coded. If your comments exceed one full source line, place another asterisk in column 1 of the next source line followed by at least one blank and continue coding the remaining comments. Note that a nonblank character is not coded in column 72 for continuation when an asterisk is coded in column 1 of the next source line. However, if your comments exceed one full source line, you can code a nonblank character in column 72 if you continue the remaining comments on the next source line starting in column 16. An asterisk must not be coded in column 1.

Example:

| LABEL | $\triangle O P E R A T I O N \Delta$ | OPERAND |  |
| :--- | :--- | :--- | :--- |
| 1 | 10 | 16 |  |


| BALR | $4, \varnothing$ |
| :--- | :--- |
| USING | $\star, 4$ |
| OPEN | CARDSIN, PRINTOUT |
| * THIS PROGRAM PREPARES AN ACCOUNTS RECEIVABLE REPORT USING CARD INPUT |  |
| * AND PRINTER OUTPUT |  |

During assembly, comments are printed but do not affect the resulting object code. The purpose of comments is to make the program listing easier to follow and can also highlight certain portions of the program.

### 1.1.5. Sequence Numbers

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. It is good practice to number the lines in multiples of 10 , or even 100. This allows you to insert additional coding lines without having to renumber the cards when they have been keypunched prior to the modification. Some programmers use letters in addition to the numbers. This is useful in identifying the deck from which cards have come if they have been removed for any reason. Sequence numbers also are important in maintaining a source module. A copy of your source module may be stored on tape or disk, and the OS/3 librarian can update and correct the source module by using the sequence numbers. (See the current version of the system service programs (SSP) user guide, UP-8062.)

### 1.1.6. Column 72

Another coding feature on the assembler coding form is column 72. This column separates the sequence field from the rest of the source line and is normally blank unless you have to continue an operand field to the next source line. If an operand specification is too lengthy to fit into the columns provided on a single line, the field may be continued onto the next line. An operand field can be continued by coding any nonblank character in column 72 and then continuing the operands on the next line starting in column 16. It is best to avoid using the comma as a continuation character when the comma is being used to separate the operand fields. However, it can be used as a continuation character when it is being used to separate operands. If you have coded up to column 72 and the next character you have to code is a comma separating operands, that comma must appear in column 16 of the next line after you code a nonblank character in column 72 (even another comma may be used).

### 1.1.7. Additional Coding Rules

The operand fields of an instruction, directive, or conditional statement must completely fill all available space on a source line, starting with the first operand specified up to and including column 71. Then a nonblank character can be placed in column 72 and the remainder of the operand field can be continued onto the next source line (column 16). These operand fields in an instruction or directive can be continued for only two additional lines.

Example:

| LABEL <br> 1 | $\triangle O P E R A T I O N \Delta$ <br> 10 | 16 |
| :--- | :--- | :--- |

The operand fields of macros and procs can be coded in two different ways:

1. The operand fields can be coded in the same manner as instructions, directives, or conditional statements, in which case they must completely fill all available space on a source line, starting with the first operand specified up to and including column 71. Then a nonblank character can be placed in column 72 and the remainder of the operand field can be continued onto the next source line (column 16).
2. The operand fields can be coded to leave space between the last operand specified on that line and the nonblank character in column 72. A comma must be placed immediately following the last operand on that line, thereby separating it from the following operand field on the next source line. However, if you omit the comma immediately following the last operand on that line, and at least one blank exists between the last operand and the nonblank character in column 72, a warning message is issued by the assembler.

The operand fields in a macro or proc can be continued for as many lines as necessary.
Examples:

| Label | $\triangle$ OPERATION $\triangle$ |  | $\triangle$ COMMENTS |
| :---: | :---: | :---: | :---: |
| 1 | 10 | 16 | 72 |
| OUTFILE | DTFMT | IOAREAI=OUTBUF,BLKSIZ , VARBLD $=(13)$, IOREG $=($ | VARBLK,SAVAREA=COMMONX UT |
| OUtFile | DTFMT | \|OAREAI=OUTBUF, <br> BLKSIZE=64 $\varnothing$, <br> RECFORM=VARBLK, <br> SAVAREA=COMMON, <br> VARBLD=(13), <br> IOREG=(12), <br> TYPEFLE=OUTPUT | $\begin{aligned} & x \\ & x \\ & x \\ & x \\ & x \\ & x \\ & x \end{aligned}$ |

It is wise to develop good coding habits from the start. A neatly coded program is easy to keypunch, debug, and interpret. Figure $1-5$ is an example of such a program. This example program follows the format of the coding form, has plenty of comments, and uses sequence numbers. Don't fall into the bad habit of jotting down instructions and keypunching and assembling them just to see if your ideas have any substance. It is much better to sit down and evaluate the problem. First flowchart your program, and then code it on the coding form, using plenty of comments and sequence numbers for lengthy programs.


Figure 1-5. Example of Proper Coding Techniques

You can, if you wish, code your assembler program in a free-form manner. The operation, operand, and comments fields don't always have to start in column 10, column 16, and column 41. These columns are shown on the coding form as preferred starting positions for each field to promote formalized coding practices. One unbreakable rule is that label field must always start in column 1. Each field after the label field must be separated by at least one blank. So, if you only have a 3-character label, the operation field can be coded starting in column 5 instead of column 10. Also note that the label, operation, and operand fields must all be keypunched on the same card. Another restriction is that the sequence numbers must always appear in columns 73 through 80 . Some examples of free-form coding are as follows:
LABEL $\triangle O P E R A T I O N \Delta$
1

As you can see, the free-form style of coding is much more difficult to interpret than the formalized style.

Another option is available, if the location of the fields on the supplied coding form doesn't suit your particular application. The assembler coding form can be changed by using the ICTL directive (21.2). By using this directive, you can change the location of the beginning, ending, or continuation column.

After a BAL source program is coded and keypunched, it must first be assembled (and also linked) before the program can be executed by the computer. These two functions are separate operations and therefore they happen at different times under control of two different computer elements. At assembly time, the assembler translates the source program to machine code instructions, and at execution time, the hardware processor performs the machine code instructions. Although you can interpret a source program as if it can actually execute, the hardware processor is incapable of actually executing this source program.

### 1.2. ASSEMBLING A PROGRAM

Before source code can be executed by a computer, it must be converted to machine code. A BAL source program is converted by an assembler, and a higher-level language, like COBOL or FORTRAN, is converted by a compiler. Whether a source program is assembled or compiled, the output is always the same. An assembler or compiler produces an object program (machine code):


The object program is a binary program that can actuate the electronic logic circuits in the hardware processor to perform specific functions like add，subtract，or divide．Any computer program must be in binary form before it can be stored in the computer and executed by the processor．

Though an assembler or compiler can produce an object program，each operates differently．Figure 1－6 shows five source lines from a COBOL program，and Figure 1－7 shows the object source code generated from the original COBOL source lines．As you can see from Figure 1－7，a single compiler source line produces several object code instructions．This is not true of assembler source lines（excluding macro instructions）；each line is converted to object code on a one－for－one basis．The object code shown in Figure $1-7$ is in hexadecimal as is any object code shown in printout form．This is because hexadecimal is easier to read and binary would take up too much room on a printout．

| IINF In． | SFo． |  | SOITRCF STATFMENT | －DEs． |
| :---: | :---: | :---: | :---: | :---: |
| กกก8ロ | 0n4019 | FRCCEDURE | Miviston． | Progul |
| nonso | 004020 | INITIALIZ |  | PROGU1 |
| กセワロの | 904021 | OPEN | indijt cas． | Prugil |
| norel | 914022 | OPEN | nutput vF＊FIL．LiGT． | PROGO1 |
| nung？ | 004023 | MOVF | Spacfs to out． | PROGO： |

Figure 1－6．COBOL Source Code


Figure 1－7．Object Code Generated from COBOL Source Code

The assembler converts each source instruction directly to a line of object code．Figure 1 － 8 shows a listing of an assembler program．The source code that was submitted to the assembler is shown at the right of the listing，and the object code generated by the assembler is shown at the left of the listing．Figure $1-8$ has a BALR assembler instruction in the second source line that uses register 6 in operand 1 and register 0 in operand 2．As you can see，in the object code part of this listing，the assembler has converted the BALR source instruction to $0560_{16}$ ．The $05_{16}$ is the machine code for a branch and link instruction；when the processor reads an $05_{16}$ ，it will perform the BALR instruction．For a listing of the machine codes for all instruction op codes，see Table E－1． The register numbers for the BALR source instruction are in the second half of the object instruction．


Very rarely will high-level language programmers read object code. Their concern is mostly with the language and the compiler. While assembler language programmers not only have the assembler and the assembler language to contend with, they also, if not just by sheer exposure, have to tolerate reading object code. This is because the assembler is really only one language step from the hardware processor. The only programming language left after assembler language is the nonsymbolic machine language. Although assembler language is closely related to the processor, it is still a symbolic programming language.

The symbolic language for the assembler has two basic types of operation codes. Those that are translated directly to machine codes and those that are not. The mnemonic codes that aren't translated to machine codes are processed only at assembly time and do not become part of the object program. Nonmachine code mnemonics are used to direct the assembler when building an object program, while machine code mnemonics make up the actual object program. Operations codes that are translated to machine codes are called assembler instructions. For a complete listing of mnemonic instruction codes and their counterpart machine codes, see Table E-1.

There are three categories of nonmachine code mnemonics in the OS/3 assembler language: directives, conditional statements, and macros. Table 15-1 is a summary of assembler directives; Table 27-1 is a summary of conditional statements; and information on the macro instructions available under OS/3 is included in the applicable user guide or programmer reference. The most commonly used macro instructions are data management and supervisor. See the data management user guide, UP-8068 (current version); data management programmer reference, UP-8159 (current version); supervisor user guide, UP8075 (current version); and supervisor programmer reference, UP-8241 (current version). The following listing shows the four elements of the assembler language and whether or not they are converted to executable code.

1. Instructions Machine Codes/Executable Code
2. Directives
3. Conditional statements $\}$ Nonmachine Codes/Nonexecutable Code
4. Macros

As stated, the main function of the assembler is to produce an object program from a BAL source program. The object program created by the OS/3 assembler is called an object module and contains other information in addition to the machine code instructions translated from your source program. This other information is generated by the assembler so that OS/3 can recognize and process the object module. Figure $1-9$ shows the format of the OS/3 object module. The shaded area indicates where the machine code program is located in the generated object module, and the remaining unshaded areas in the object module are used by the linkage editor, which is an OS/3 system program that creates another module called a load module. For further details about the contents of an object module, see the system service programs (SSP) user guide, UP-8062 (current version).


Figure 1-9. OS/3 Object Module Format

### 1.3. CREATING A LOAD MODULE

Assembling a program is only the first step in generating an executable BAL program. The complete process is a 3 -step sequence and is generally called an assemble, link, and go operation. This means you must assemble an object module and create (link) a load module before you can execute (go) a BAL program. To set up an assemble, link, and go operation, or an assemble only (if only an assembly is required), you must use job control statements. Section 29 gives detailed information on how to run a BAL job.

Although the object module created by the assembler contains a BAL program in machine code form, it still isn't an executable program. To be executable (in OS/3) the object module must be changed to a load module. After an object module is generated, the assembler is no longer in control and the object module, left behind by the assembler, is used as input for creating a load module. The next OS/3 system program to gain control builds a load module from the object module. This system program is called the linkage editor.

The format of the load module produced by the linkage editor is illustrated in Figure $1 \mathbf{1 0}$. The shaded area indicates where the machine code program is located in the load module. For detailed information about the contents of a load module see the system service programs (SSP) user guide, UP-8062 (current version). Segments phase 1 through phase $n$ shown in Figure 1-10 aren't created unless you specifically do so with linkage editor control statements. However, every load module will always have a root phase. After a load module is created, the BAL program is ready for execution.

### 1.4. PROGRAM EXECUTION

During the assemble and link phase, each type of BAL module is on disk, while during the program execution phase, the machine program is stored in main storage as a load module. Figure 1-11 shows the location of each module after assembly time and linkage editor time. The source, object, and load modules are stored in a disk file called the job's run library file ( $\$ Y \$ R U N$ ). This file is an OS/3 system file, which is used to hold each BAL module until the assembler, link, and go job is finished.

The focal point of program execution is main storage. Once the load module is loaded from disk to main storage, the machine instructions are fetched one at a time from main storage by the processor. When the processor fetches an instruction, the op code is decoded to find out which instruction is to be executed. If the instruction is legal, it is executed and the processor fetches another. This goes on until no machine instructions are left in the load module.

The only codes that the processor can interpret are the machine codes for assembler instructions. Any other codes submitted to the processor will cause an error, and the offending program is aborted. Every machine code instruction in the BAL instruction repertoire is supported by the micro code loaded into the control storage of the system. It is important to realize that machine codes, and only machine codes, can drive the hardware processor. This is the key to understanding the difference between program execution time and assembly time. At assembly time, the assembler processes the source program; the processor cannot execute a source program and doesn't see your program until it is in machine code form.


Figure 1-10. OS/3 Load Module Format


Figure 1-11. Assemble, Link, and Go Operation

## 2. Data Forms

### 2.1. DATA REPRESENTATION

Computer data is stored in special code combinations used to represent all the characters and numerical data needed for problem solving. The smallest area the computer can move or manipulate is called a byte, which is composed of eight units called bits. Each bit is either a 1 or a 0 ; thus, a byte representing the letter $M$ would look like this:


Bits are numbered from left to right, with the leftmost bit referred to as the zero bit or the most significant bit (MSB). The rightmost bit in this byte is the number seven bit. The rightmost bit in any field, no matter how long, is also referred to as the least significant bit (LSB). Two contiguous bytes are called a half word; four are called a full word; and eight are a double word. When you manipulate several bytes as a string, the leftmost byte is called the most significant byte (MSB), and the rightmost byte is the least significant byte (LSB). Additional information on bit and byte structure is given in 4.3.2.

Table 2-1 comprises different methods of organizing and referencing numeric data as you would use them in data processing.

Table 2-1. Comparison of Numeric Expressions

| Type of Number | Examples |  |  |  | Decimal Values |
| :---: | :---: | :---: | :---: | :---: | :---: |
| Character form (unpacked) |  | F: 5 | F $\quad 0$ | F 0 | 500 |
| Zoned decimal ( + ) |  | F:5 | F 0 | c: 0 | +500 |
| Zoned decimal (-) |  | F 5 | F 10 | D: 0 | -500 |
| Packed decimal ( + only) |  |  | 5 O | 0 F | +500 |
| Packed decimal, signed ( + ) |  |  | $5: 0$ | $0: 10$ | +500 |
| Packed decimal, signed (-) |  |  | 5 0 | 0 D | -500 |
| Hexadecimal (+ only) |  |  | 0 1 | F 14 | $+500$ |
| Floating point ( + ) | 4 3 | 1 (F | 4 l | 0 0 | +500 |
| Floating point (-) | C 13 | 1 F | 410 | 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 |

### 2.2. BINARY REPRESENTATION

In binary language, the same principles are followed as in decimal language. In decimal language (base 10), the number 251 is a combination of three values:

|  |  | 5 |  | a value of one unit |
| :---: | :---: | :---: | :---: | :---: |
| 1 |  |  | 1 |  |
| 50 +200 |  | 5 |  | the value of five 10 's |
| 251 | 2 |  |  | the value of two 100's |

In binary (base 2), the rightmost digit has the decimal value of 1 ; the digit to its left has a decimal value of 2 , the next is 4 , then 8 , and so on to the most significant bit, which in one byte, has the decimal value of 128 . You determine the total value of a binary number by adding the decimal value of each "on" bit (1), as illustrated in Figure 2-1.


Figure 2-1. Determining Binary Values
Starting with the value of zero, a full byte represents a total of 256 different codes (B.1) and a half byte represents 16 codes. Since binary notation is unwieldy, most notations are written and computer-printed in other forms.

### 2.3. HEXADECIMAL REPRESENTATION

Using base 16 values, there are 256 hexadecimal codes in one byte. The hexadecimal notations consist of the numbers 0 through 9 and the letters A through F. In this way, we can represent the maximum decimal value of a half byte, which is 15 , by one hexadecimal notation, which is F (Table 2-2). In B.1, the relationship of the binary, decimal, and hexadecimal codes for a full byte is shown.

Hexadecimal representation is an outgrowth of decimal and binary representation of data. In decimal, the base used is 10 ; therefore, the decimal number 251 is in actuality:

which is the same as saying:

$$
(2 \times 100)+(5 \times 10)+(1 \times 1)=251
$$

If we take this same number, 251, and show it in binary notation (that is, use the base 2), it would look like this for one byte:


This is the same as:

$$
\left(1 \times 2^{7}\right)+\left(1 \times 2^{6}\right)+\left(1 \times 2^{5}\right)+\left(1 \times 2^{4}\right)+\left(1 \times 2^{3}\right)+\left(0 \times 2^{2}\right)+\left(1 \times 2^{1}\right)+\left(1 \times 2^{0}\right)
$$ or:

$$
(1 \times 128)+(1 \times 64)+(1 \times 32)+(1 \times 16)+(1 \times 8)+(0 \times 4)+(1 \times 2)+(1 \times 1)=251
$$

Hexadecimal notation reduces the time and space needed to read or write the codes represented by a full byte of binary information. Because 16 is the base, to convert binary data to hexadecimal data, divide the binary representation of the decimal number into groups of four bits and pad to the left as necessary to obtain a full grouping of four bits. Thus, taking the binary representation of the decimal number 251 and breaking it up into groups as just described, we get:


Table 2-2. Hexadecimal Notation

| Binary <br> Half Byte | Decimal <br> Value | Hexadecimal <br> Code |
| :---: | :---: | :---: |
| 0000 | 0 | 0 |
| 0001 | 1 | 1 |
| 0010 | 2 | 2 |
| 0011 | 3 | 3 |
| 0100 | 4 | 4 |
| 0101 | 5 | 5 |
| 0110 | 6 | 6 |
| 0111 | 7 | 7 |
| 1000 | 8 | 8 |
| 1001 | 9 | 9 |
| 1010 | 10 | A |
| 1011 | 11 | $C$ |
| 1100 | 12 | $D$ |
| 1101 | 13 | E |
| 1111 | 14 | $F$ |

### 2.4. CHARACTER REPRESENTATION

There are 256 possible bit combinations that can be stored in a byte. By convention, certain bit combinations are used to represent the letters, numerics, and special characters that are used to convey information in written form. In B. 1 are listed the hexadecimal equivalents of the characters used to write programs. It is also pointed out in this document that only certain characters are used in statement formats. To aid in the specification of permissible characters, the overall character set of the assembler 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) () . \& $\gg<$


### 2.4.1. Alphabetic Characters

The letters A through $Z$ are alphabetic characters and part of the alphabetic set. The following table shows the hexadecimal representation, which is one byte long, for each of the uppercase letters. (Also see B.2.)

| Alphabetic Character | Hexadecimal (EBCDIC) Code | Alphabetic Character | Hexadecimal (EBCDIC) Code |
| :---: | :---: | :---: | :---: |
| A | C1 | N | D5 |
| B | C2 | 0 | D6 |
| C | C3 | P | D7 |
| D | C4 | Q | D8 |
| E | C5 | R | D9 |
| F | C6 | S | E2 |
| G | C7 | T | E3 |
| H | C8 | U | E4 |
| । | C9 | $\checkmark$ | E5 |
| J | D1 | W | E6 |
| K | D2 | $X$ | E7 |
| L | D3 | Y | E8 |
| M | D4 | Z | E9 |

### 2.4.2. Special Letters

The following special letters are part of the alphabetic set and usually follow the same rules as the letters mentioned in 2.4.1. The hexadecimal representation for these special letters are listed in the following table (also see B.2):

| Special <br> Letters | Hexadecimal <br> (EBCDIC) Code |
| :---: | :---: |
| $?$ | 6 F |
| $\$$ | 5 B |
| $\#$ | 7 B |
| $@$ | 7 C |

### 2.4.3. Numeric

As previously noted, all characters are coded in a full byte (eight bits), and this is also true for the character forms (unpacked) of numbers. Numbers written in this form, just as letters and other characters, can be moved from one location in main storage to another and can be sequenced, compared, and treated in other ways; but mathematical operations can not be performed on unpacked numerics. To do mathematical operations, the values must be in binary or packed decimal form. Unpacked and packed numeric formats are explained in 2.4.3.1 and 2.4.3.2. All numeric forms are shown in Extended Binary-Coded Decimal Interchange Code (EBCDIC). For the American Standard Code for Information Interchange (ASCII), see B.3.

### 2.4.3.1. Unpacked Format

Unpacked (printable) numeric characters are coded in a full byte and are easily recognized because the first half of the coded byte is the hexadecimal code $F$. The decimal digit 5 is represented in a byte as F5. The $F$ half of the byte (bits 0 through 3 ) is the zone field, and the 5 (bits 4 through 7) is in the digit field. Numeric data must be in this unpacked format to be output to a printer unit.


The following shows the hexadecimal 1-byte unpacked code for each decimal digit.

| Decimal <br> Digit | Hexadecimal <br> (EBCDIC) Code |
| :---: | :---: |
| 0 | F0 |
| 1 | F1 |
| 2 | F2 |
| 3 | F3 |
| 4 | F4 |
| 5 | F5 |
| 6 | F6 |
| 7 | F7 |
| 8 | F8 |
| 9 | F9 |

Examples of decimal digits and their unpacked byte equivalents are shown here.


### 2.4.3.2. Packed Format

As you can see, unpacked format involves a considerable waste of main storage space. When numbers are to be processed, they can be converted to packed format by means of the PACK instruction, prior to processing. In packed format, the zone fields are stripped away and the number is stored as follows:


Thus, in packed format, only two bytes are needed to store the decimal number 107. This results in considerable savings in main storage space. After mathematical operations on a packed number, the sign $C$ indicates a positive value and the sign $D$ a negative value in EBCDIC.

+107 (signed)
-107 (signed)
unsigned (assumed positive)

The following program extract shows how the PACK instruction is used. (See 9.7.)

|  | PACK | AREA1,NO1 | Area NO1 is packed into AREA1. |
| :--- | :--- | :--- | :--- |
|  | AP | AREA1,ONE | A sign code is produced. |
|  | $\cdot$ |  |  |
| NO1 | DC | C'123. |  |
| AREA1 | DS | CL2 |  |
| ONE | DC | PL'1. |  |

After these operations, the two main storage areas will look like this:

NO1

| $F$ | 1 | $F$ | 2 | $F$ | 3 |
| :--- | :--- | :--- | :--- | :--- | :--- |

AREA1


The hexadecimal code C in AREA1 indicates that the value is positive. If the value is to be indicated as a negative value, a hexadecimal code of $D$ would be in this field.

### 2.4.4. Special Characters

The following 14 special characters are not part of the alphabetic set (2.4.1), special letters (2.4.2), nor are they numeric (2.4.3). They have special uses, and rules are covered in this user guide when required. Following are listed the special characters with their hexadecimal codes for reference. (Also see B.2.)

| Special Character | Hexadecimal (EBCDIC) Code | Special Character | Hexadecimal (EBCDIC) Code |
| :---: | :---: | :---: | :---: |
| + | 4 E | ( left parenthesis | 4D |
| - (minus) | 60 | ) right parenthesis | 5D |
| * | 5 C | ( (period) | 4B |
| / | 61 | \& | 50 |
| , (comma) | 6 B | ' (prime) | 7 D |
| $=$ | 7 E | > | 6 E |
| $\Delta$ (blank) | 40 | $<$ | 4 C |

### 2.5. FIXED-POINT NUMBERS

Each fixed-point number is represented in one of three fixed-length binary formats composed of a single positive or negative sign bit followed by a number field (Figure 2-2). 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. For additional information on fixed-point numbers, see 2.1, 5.2.6, 5.2.7, and Section 10.

HALF WORD


FULL WORD

| $s$ <br> 1 <br> 6 |  |  |  |
| :--- | :--- | :--- | :--- |
| $N$ |  | NUMBER FIELD | 31 |
|  | 1 |  |  |

DOUBLE WORD


Figure 2-2. Fixed-Point Number Formats

### 2.6. FLOATING-POINT NUMBERS

The assembler provides floating-point arithmetic operations as an optional hardware feature. Floating-point arithmetic operations involve a fraction and an exponent. For example:

217,000 can be expressed as $0.217 \times 10^{6}$
296,000 can be expressed as $0.296 \times 10^{6}$
In fixed-point arithmetic, add:

$$
\begin{array}{r}
217,000 \\
+\quad 296,000 \\
\hline 513,000
\end{array}
$$

In floating-point arithmetic, add:

$$
\begin{array}{r}
0.217 \times 10^{6} \\
+\quad 0.296 \times 10^{6} \\
\hline 0.513 \times 10^{6}
\end{array}
$$

where:
0.513 is the fraction and $10^{6}$ is the exponent.

In floating-point notation, the fraction is added and the exponent is retained. The example uses decimal floating-point; the assembler uses hexadecimal floating-point. In hexadecimal floating-point notation, 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 most significant digit. The quantity expressed by the full floating-point number is the product of the fraction and the number 16 raised to the power minus 64 of the biased exponent (fraction $\times 16^{n-64}$ ). For additional information on floating-point numbers, see 5.2.12 and Section 11.

| $S$ | characteristic <br> (exponent) | mantissa <br> (fraction) |
| :---: | :---: | :---: |
| $\mathbf{G}$ |  |  |

## 3. Addressing

Each full byte (eight bits) of main storage is numbered in sequence starting with 000000. With the assembler, the address of each instruction is calculated and you can refer to it by its real address or by a symbolic notation assigned to it. The assembly listing shows these addresses in their hexadecimal form. The computer also contains 16 registers that can be used for addressing and storage. The many types and uses of addressing are covered in detail in the following parts of this user guide.

### 3.1. MAIN COMPUTER STORAGE ADDRESSING

If you wish to refer to some other part of your program, you assign a symbol to that location and the assembler translates this to the real main storage address.

### 3.1.1. Instruction Addressing

Your program may contain the move instruction MVC:

| LABEL | $\triangle O P E R A T I O N \Delta$ | OPERAND |
| :--- | :--- | :--- |
| 1 | 10 | 16 |

MOVE5 MVC MYAREA, YOURAREA

Even though the main storage for this application instruction is 00008A, you could return (branch) to this instruction by writing:

B MOVE5

This type of referencing a location in a program is called symbolic addressing. It is a time saver and helps eliminate many errors.

### 3.1.2. Data Field Addressing

As noted in 1.2, storage and data areas are defined for later reference. The following list shows assembler-generated addresses, the symbolic addresses assigned by you, and the storage areas.

| Assembler-Generated Address | Symbolic Address | Definition |  |
| :---: | :---: | :---: | :---: |
| 000048 | WKAREA 1 | DS | CL41 |
| 000071 | WKAREA2 | DS | CL16 |
| 000081 | MYAREA | DS | OCL121 |
| 000081 | OUTPUT1 | DS | OCL121 |
| 000081 | NEWAREA1 | DS | CL41 |
| 0000AA | NEWAREA2 | DS | CL80 |
| 0000FA | YOURAREA | DS | OCL121 |
| 0000FA | INPUT1 | DS | OCL121 |
| 0000FA | COUNTS | DS | OCL3 |
| 0000FA | COUNT5 | DC | CL1 ${ }^{\prime} 5^{\prime}$ |
| 0000FB | COUNT12 | DC | CL2'12' |
| O000FD |  | DS | CL118 |

The first work area shown, WKAREA1, has the hexadecimal location 000048 and is 41 bytes long. The hexadecimal value of 41 is 29 , which added in hexadecimal produces the next hexadecimal location 000071 . The next areas, MYAREA and OUTPUT1, show how we can assign different symbols to the same area. They do not take up main storage space and thus have the same address as NEWAREA1, which is 16 bytes from the start of the last address. The hexadecimal value of 16 is 10 ; thus, the address of NEWAREA1 is 000081 . This address plus 41 bytes (hexadecimal 29) produces the next address, 0000AA.

The use of either the symbol MYAREA or OUTPUT1 calls for the same 121 bytes following them in storage. The zero placed in front of the CL instructs the assembler to assign a location for these symbols but not to reserve any storage for them. The remaining six instructions show how this can be done with constants (DC) as well. The symbol COUNTS is an example of a symbol reference within another symbol reference.

### 3.2. REGISTER ADDRESSING

There are 16 general registers ( 0 through 15). Each register consists of 32 bits which is equivalent to a fullword. Any register can be used in RR, RS, or RX type instructions. Any register can also be used in base register assignment. However, most I/O operations use registers $14,15,0$, and 1 . So, if you use any one of these registers and then perform either input or output, the original data in these registers is destroyed. You can use these registers, though, by saving their contents prior to the execution of an I/O operation and restoring their contents after the execution of an I/O operation.

## 4. Rules and Conventions

### 4.1. READING INSTRUCTION NOTATION

Notations are used throughout this manual to describe the general forms of programmerwritten and computer-generated formats. A consolidated listing of all the notations is included in Figure 7-1. This section includes the definitions of terms.

### 4.1.1. Assembler Application Instruction Notations

There are six forms of assembler applications instructions:

$$
\begin{aligned}
& \text { RR }- \text { Register-to-Register } \\
& \text { RX - Register-to-Indexed-Storage or Storage-to-Indexed-Register } \\
& \text { RS - Register-to-Nonindexed-Storage or Storage-to-Nonindexed-Register } \\
& \text { SI - Storage Immediate } \\
& \text { SS - Storage-to-Storage (Type SS1) } \\
& \text { SS - Storage-to-Storage (Type SS2) }
\end{aligned}
$$

Assembler application instructions provide the format for hand-written coding that, in turn, leads to the assembler format that generates the machine coding. The assembler application move instruction (MVC) illustrated is an SS1 type. The coding is described on the following page. Definitions of the explicit and implicit formats are provided in Section 7.

Explicit Format:

| LABEL | DOPERATION $\Delta$ |  |
| :---: | :--- | :--- |
| Osymbol] | MVC | $\mathrm{d}_{1}\left(\mathrm{I}_{1}, \mathrm{~b}_{1}\right), \mathrm{d}_{2}\left(\mathrm{~b}_{2}\right)$ |

Implicit Format:

| LABEL | $\triangle$ OPERATION $\Delta$ | OPERAND |
| :---: | :--- | :--- |
| $\cdot$ | MVC | $s_{1}\left(I_{1}\right), s_{2}$ |

On the coding sheet, it could look like this:

```
LABEL \(\triangle\) OPERATIOND
1
\(10 \quad 16\)
```

OPERAND

OUT4 MVC AREA (37), NETPAY
where:

## [symbol]

The brackets around symbol mean OUT4 is optional.

## MVC

Is the mnemonic opcode for the move instruction.

## AREA(37)

Is the first operand: $d_{1}\left(l_{1}, b_{1}\right)$ or $s_{1}\left(l_{1}\right)$ AREA is the address $d_{1}\left(b_{1}\right)$ or symbol $s_{1}$ and $(37)$ is the length $\left(I_{1}\right)$ of the receiving field to be filled.

## NETPAY

Is the second operand: $\mathrm{d}_{2}\left(\mathrm{~b}_{2}\right)$ or $\mathrm{s}_{2}$.
After this application instruction is assembled, it is in the following form:


And could have the generated machine code:
D2 24 44FC 4AA6
where:
D2
Is the operation (opcode) for the mnemonic MVC.
24
Is the hexadecimal coding for the length $\left(I_{1}\right)$, which is 37 bytes long but assembled as $37-1$ or 36 .

4
Is the base register $b_{1}$ used for the first operand.
4FC
Is the displacement $d_{1}$ used for the first operand.
4AA6
Is the base $b_{2}$ and displacement $d_{2}$ address of the second operand NETPAY.
The generated machine code is expressed in hexadecimal form. Knowing the organization of the machine code format can help you when the written coding does not generate the values you intended. Such knowledge helps in finding errors in the results of a program. (See Figure 4-1).

Consider another instruction:

| LABEL | $\triangle$ OPERATION $\triangle$ | OPERAND |
| :---: | :--- | :--- |
| [symbol] | L | 6,GROSSPAY(5) |

where:
L
Is the mnemonic opcode for the load instruction.
6
Is the first operand register $r_{1}$.

## GROSSPAY(5)

Is the second operand in the form $\mathrm{s}_{2}\left(\mathrm{X}_{2}\right)$.
After this application instruction is assembled, it may generate the following machine code:
where:
58
Is the opcode for the load instruction.
6
Is the register $r_{1}$ used for the first operand.
5
Is called the index register and is part of the second operand.
4012
Is the base $b_{2}$ and displacement $d_{2}$ for the second operand address GROSSPAY. For a discussion of how the processor uses the base register, index register, and displacement of an operand to form main storage addresses, refer to the current version of the processor programmer reference.

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. The last statement in the source module may not be continued into the source program being assembled. Statements included in the program by a COPY directive are assumed to be in standard format regardless of any ICTL directives in the program.

Figure 7-1 shows the formats of the six application instructions as generated by the assembler in machine code, as well as the explicit and implicit formats for programmer coding. Examples of the implicit coding format using symbols and the explicit format are included in following sections for each assembler application instruction. More detailed information on the use of the assembly listing is in Section 28.

### 4.1.2. Notation Rules and Meanings

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

- Optional information is enclosed in brackets [ ] and may be specified or omitted as in the use of [symbol].
- Braces \{ \} indicate multiple options, at least one of which must be chosen, as in the following directive.

For example:
PRINT $\left\{\begin{array}{l}\text { ON } \\ \text { OFF }\end{array}\right\}$

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

For example:



Figure 4-1. Assembler Format Relationships

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

For example:


- Uppercase letters, terms, and punctuation marks indicate information which must be coded exactly as shown. Also, mnemonic codes (such as MVN, PACK, and CLC) are in uppercase letters.
- Lowercase letters and terms indicate variables (such as [symbol], r, d, b, and e) which are supplied by you.
- An ellipsis, a series of three periods, indicates that a series of entries may be coded, as in the directive DROP $r$, $\left[, r_{2}, \ldots, r_{n}\right]$.
- Keyword parameters may be coded in any order.

For example:

$$
\begin{aligned}
& \text { IOROUT=LOAD,BLKSIZE=512,RECFORM=FIXBLK } \\
& \text { BLKSIZE=512,IOROUT=LOAD,RECFORM=FIXBLK }
\end{aligned}
$$

- 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:
$X^{\prime} 03^{\prime}$, OUTP, $X^{\prime} 00^{\prime}, 132$ (operand field of CCW)
$\& P, 3, \& K E Y 1=, \& K E Y 2=, \& K E Y 3=$ (operand field of macro statement in proc format)

- Names of directives and instructions in text are shown in lowercase italics.

For example:
add, move, load, branch and link, store

- Throughout this manual, the register notations RO through R15 represent the registers 0 through 15.

For example:
BALR R2,R3
The hand-written program, usually on the assembler coding form, is called the source program; the keypunched cards containing this coding are still called the source program or source cards or source deck. The source program is assembled, and the assembler usually produces a translation of the source program into machine code; this deck is called the object program. A printed listing of the assembled program, called the assembly listing, shows the source coding with its associated assembled machine coding.

The smallest unit of information in basic assembly language (BAL) is the bit. Eight bits make a byte and two bytes form a half word. Four bytes are a full word and eight bytes comprise a double word. Figure 4-2 shows the relationships between bits, bytes, and words. Bits 0 through 7 form the high-order byte or MSB, and bits 56 through 63 form the low-order byte or LSB in a double-word storage area.


Figure 4-2. Byte and Word Structure

The following short definitions should be useful for the new programmer.

- Source program

Programmer-produced

- Source cards

Keypunch output

- Source deck

Keypunch output

- Machine code

Assembler-generated

- Object program

Assembler output

- Assembly listing

Assembler output to printer

- Bit

One binary digit

- Byte

Eight binary digits

- Half word

Two bytes

- Full word

Four bytes

- Double word

Eight bytes

- MSB

Most significant bit or byte, leftmost

- LSB

Least significant bit or byte, rightmost

- High order

Leftmost data, byte, or bit

- Low order

Rightmost data, byte, or bit

### 4.2. TERMS

Terms represent values coded by the programmer or computed by the assembler. There are five classes of terms recognized by the assembler:

- $\quad$ Self-defining terms (SDT)
- Literals
- Symbols
- Location counter references
- Length attribute references

Self-defining terms are fixed values the programmer codes such as $33, \mathrm{P}^{\prime} 591^{\prime}, \mathrm{X}^{\prime} O F^{\prime}, \mathrm{B}^{\prime} 11100110^{\prime}$, or $\mathrm{C}^{\prime} E \mathrm{BW}^{\prime}$. Literals can have their value specified by the programmer and their location decided by the assembler and could look like, $=X^{\prime} F O^{\prime},=C^{\prime} A^{\prime},=P^{\prime}-1^{\prime}$, or $=B^{\prime} 00001000^{\prime}$ as used in storage-to-storage instructions (e.g., CLC TAGA, $=C^{\prime} A^{\prime}$ ). Symbols, location counter references, and length attribute references are assigned values by the assembler. (See Table 4-1.)

Table 4-1. Comparison of Terms

| Term |  | Examples |
| :---: | :---: | :---: |
| SDTs <br> Can be used in the 1 st or 2 nd operands. <br> May be used in application instructions and in assembler directives. | CLI <br> MVI <br> MVC | AREA $10 \cdot \underbrace{10}_{\text {SDT }}$ AREAB, $\underbrace{X^{\prime} \mathrm{C} 2}_{\text {SDT }}$ 33 (10,R5),3(R8) SDT SDT SDT |
| Literals <br> May not be used in assembler directives. <br> Literals are preceded by an equal (=) sign. | MVC <br> MVC <br> CLC | $\begin{aligned} & \text { AREA } 10,=\frac{C^{\prime} 10^{\prime}}{\text { Literal }^{\prime}} \\ & \text { AREA } 10=\underbrace{\text { Literal }}_{\text {Literal }^{\prime \prime}{ }^{\prime} 1 F 0^{\prime}} \end{aligned}$ |
| Symbols for constants <br> May be used in the 1st or 2nd operands. <br> May be used in application instructions and in assembler directives. | AREA10 <br> NO10 <br> MOVE 10 | DS CL2 <br> DC C' $10^{\prime}$ <br> MVC $\underbrace{\text { AREA } 10, N O 10}_{\text {symbols }}$ |

### 4.2.1. Self-Defining Terms (SDT)

Self-defining terms (SDT) are 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 you 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. (See 5.2.)

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 up to 24 zeros and ones enclosed in apostrophes and preceded by the letter B (e.g., $\left.B^{\prime} 101^{\prime}, B^{\prime} 11110000^{\prime}, B^{\prime} 00101^{\prime}\right)$. 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., $\mathrm{X}^{\prime} \mathrm{FO}^{\prime}, \mathrm{X}^{\prime} \mathrm{C1}^{\prime}, \mathrm{X}^{\prime} \mathrm{F} 1 \mathrm{FOFO}$ '). Each hexadecimal digit represents a half byte of information.
- A decimal SDT is an unsigned decimal number consisting of up to eight digits having a value of 0 through $16,777,215\left(2^{24}-1\right)$ (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. (See Appendix B, Table B-1.) The characters must be enclosed in apostrophes and preceded by the letter C (e.g., $C^{\prime} A^{\prime}, C^{\prime} A B C^{\prime}, C^{\prime} 123^{\prime}, C^{\prime} A 1^{\prime}$ ). 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 which delimit the SDT (e.g., C'3'S' produces 3'S;C'A\&\&B' produces A\&B).

The following four examples all produce the same internal bit pattern of 11110001 in the one byte area called AREA:

- Decimal CLI AREA, 241
- Hexadecimal CLI AREA, X'F1'
- Character CLI AREA, C'1'
- Binary CLI AREA, B‘11110001'


### 4.2.2. Literals

Literals are terms that represent data in the source coding (see 5.3). The assembler replaces the value of the original literal in the literal table (pool) with the address of the main storage location. In the following example the literal $=C^{\prime} A A^{\prime}$ will be replaced in this instruction by the address of a 2-byte area in the literal table containing the binary value 1100000111000001.

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. 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. ' S ' type constants may not be used as literals.

### 4.2.3. Symbols

A symbol is a group of up to eight alphanumeric characters. The left, or leftmost, character must be alphabetic. Special characters or blanks may not be contained within a symbol. (See Section 6). The following are examples of valid symbols:

| V | CARDAREA |
| :--- | :--- |
| GS279 | RSINTRN |
| BOB | BD\#4 |

The following are not valid symbols for the reasons stated:

| READ ONE | Embedded blank |
| :--- | :--- |
| SPEC'L | Special character used |
| 6AGN | First character not alphabetic |

Two other categories of symbols are available in the macro language and conditional assembly statements. They are variables symbols and sequence symbols. These categories of symbols are defined and discussed in detail in Section 6 and in 27.2.1.

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. (See Section 16.)

- Value Attribute

A symbol is assigned a value, or defined, 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 (5.1.7.), 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$.

## - Length Attribute

The length attribute of a symbol is 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. (See 5.1.3.)

The maximum length attribute that can be generated by the assembler is 65,536 .

- Relocatability Attribute

A symbol may either be absolute or relocatable. Values which are assigned to symbols defined in the label field of a source code line representing an instruction, constant, or storage definition, are relocatable. 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 0 .

### 4.2.4. Location Counter References

A location counter is 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^{23}-1$.

Each instruction must have an address which 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 O'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 which were by-passed 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 asterisk character (*). 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. Care must be taken to ensure that all such implied references are specified appropriately in individual expressions since the character asterisk (*) may also be used to indicate the multiply operator during the evaluation of expressions.

An instruction may address data or other instructions in its immediate vicinity in terms of its own storage address. This is one kind of relative addressing and it is achieved by an expression of the form ${ }^{*}+\mathrm{n}$ or ${ }^{*}-\mathrm{n}$ where n is the difference in storage addresses of the referencing instruction and the instruction or data being accessed. Relative addressing is always in terms of bytes and not in terms of words or instructions.

A location counter reference may not be made in a statement which requires the use of a predefined symbol, with the exception of the EQU and ORG directives.

### 4.2.5. Length Attribute Reference

The length attribute of a symbol is 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 it would have a value of 4. (See 5.1.5.)

### 4.3. OPERATORS

There are 12 operators in the assembler language (Table 4-2) that designate the method and sequence to be employed in combining terms or expressions. Blanks are not permitted within an expression. 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 as listed in Table 4-2. The operation with the highest hierarchy number is performed first; operations with the same hierarchy number are performed from left to right.

Parentheses can be used to alter the hierarchy of evaluation. Multiplication by 0 equals 0 . The 12 operators are divided into three classes: arithmetic operators, logical operators, and relational operators. More detailed descriptions of these operators are provided in 4.3.1, 4.3.2, and 4.3.3.

Table 4-2. Summary of Operators (Part 1 of 2)

| Classification | Operator | Description | Hierarchy |
| :---: | :---: | :---: | :---: |
| Arithmetic Operators | */ | $A^{*} / B$ is equivalent to $A^{*} 2^{B}$ | 6 |
|  | $1 /$ | Covered quotient, $A / / B$ is equivalent to $(A+B-1) / B$ | 5 |
|  | 1. | $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 AND of $A$ and $B$. | 3 |
|  | ++ | $A++B$ means Logical Sum OR of $A$ and $B$. | 2 |
|  | -- | A--B means Logical Difference XOR of $A$ and $B$. | 2 |

Table 4-2. Summary of Operators (Part 2 of 2)

| Classification | Operator | Description | Hierarchy |  |
| :---: | :---: | :---: | :--- | :---: |
| Relation 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 |

### 4.3.1. Arithmetic Operators

The symbols $+,-,^{*}, /, / /, * /$ represent the six arithmetic operators. 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^{*} 2^{B} . A^{*} /(-B)$ indicates a right shift and is equivalent to $A / 2^{B}$.

### 4.3.2. Logical Operators

The symbols ${ }^{* *},++$, and —— are the three logical operators. The characters ${ }^{* *}$ represent the logical product (AND), and characters ++ represent the logical sum (OR), and the characters - represent the symmetric difference (exclusive OR).

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. (See Section 12.) The result of the bit comparison for each operator is:


### 4.3.3. Relational Operators

The three relational operators are the equals operator $=$, the greater than operator $>$, and the less than operator $<$.

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, than 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 (4.4.5) 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.

### 4.4. EXPRESSIONS

An expression consists of 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 relocatability 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.
- 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 which compose them. These three types of expressions are discussed in 4.4.1 through 4.4.6.

### 4.4.1. Absolute Expressions

An absolute expression is 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 which 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 which 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 examples of absolute expressions:
$A$
$A+A-A$
$A-A+A+A$
$R+A-R$
$R-R+A$
$(R-R)^{*} A$
$A^{*} A$
where:

A
Is an absolute term.
R
Is a relocatable term.

### 4.4.2. Relocatable Expressions

A relocatable expression is 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 examples of relocatable expressions:

R
R/1
$R+A$ or $A+R$
$R-R+R$
R-A
R*1 or 1*R
where:
A
Is an absolute term.
R
Is a relocatable term.

### 4.4.3. Complex Relocatable Expressions

A complex relocatable expression is an expression that contains 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 Atype or Y-type address constant. (See 5.2.8 and 5.2.9.)

Some examples of complex relocatable expressions are:
A-R
-R/1
$A-R-R+R-R$
where:
A
Is an absolute term.
R
Is a relocatable term.

### 4.4.4. Character Expressions

A character expression is either a character string, a character substring, or a concatenation of strings or substrings. Character expressions are used as the operand of a SET or SETC statement or as terms in a SETB, SET, AIF, or DO relational expression. Any character string is considered to be greater in value than any shorter character string. $A$ character expression may have a length of up to 127 characters.

### 4.4.5. Length Attribute of Expressions

The length attribute of an expression is determined by the assembler and it 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.

### 4.4.6. Character Strings

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.
- Two ampersands must be written within a character string to represent one ampersand. 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 ( $\mathbf{e}_{1}, \mathbf{e}_{2}$ )
where:
$\mathbf{e}_{1}$
Specifies the leftmost character of the original string to be included in the substring.
$\mathbf{e}_{2}$
Specifies the number of characters to be in the substring.
The expressions $\mathrm{e}_{1}$ and $\mathrm{e}_{2}$ must be valid SET expressions. (See 27.1.4.) 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.

## Example:

'PREDEFINED' $(4,6)$
will produce the character substring
'DEFINE'
Concatenation is the joining together of:

- two character strings;
- two character substrings; or
- a character string and a character substring.

A period designates concatenation into a string of characters.

## Example:

'PRE'.'DEFINE' produces
'PREDEFINE'
When a substring is to be concatenated with a following character string, the period may be omitted and concatenation is assumed.

## PART 2. STORAGE AND SYMBOL DEFINITIONS <br> y

## 5. Storage Definitions

In almost all programs, inclusion of constant value is required for mathematical computation, headings for reports, and values or codes for comparisons. You also reserve storage for work areas, record keeping, and save areas. Two methods used to produce constants or reserve storage are:

- define constant - DC
- define storage - DS


### 5.1. STORAGE USAGE

There are 13 definition types used to describe the type and format of storage used. Table $5-1$ lists the characteristics of each of these storage notations. All the definition types shown are valid for both DC and DS statements. Except for floating-point constants (2.9, 5.2.12, and Section 11), the formats of both statement operands are similar, as follows:

| Label | $\triangle$ OPERATION $\Delta$ |  |
| :---: | :--- | :--- |
| Osymbol] | DC | $[d] t\left[L_{n}\right]\left\{\begin{array}{c}c^{\prime} c^{\prime} \\ (c)\end{array}\right\}$ |
| [symbol] | DS | $[d] t\left[L_{n}\right]\left[\begin{array}{c}c^{\prime} c^{\prime} \\ (c)\end{array}\right]$ |

where:

## [symbol]

Is up to eight characters.
d
Is the duplication factor in decimal.
t
Is the definition type. (See Table 5-1.)
$L_{n}$
Is the explicit length factor in decimal.
'c'
Is the constant specification for data.
(c)

Is the constant specification for an address.

Table 5-1. Characteristics of Constant and Storage Definition Types

| Type Code | Constant or Storage Type | Alignment | Source Code Specification |  | Storage Format | Truncation or Padding | Length in Bytes |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  |  |  | Implied |  | Minimum Explicit | Maximum Explicit * |
| C | Character | None | Characters | $C^{\prime}$ |  | Character | Right | Variable | 1 | $\begin{aligned} & 256 \text { (DC) } \\ & 65,535 \text { (DS) } \end{aligned}$ |
| $x$ | Hexadecimal | None | Hexadecimal digits | ${ }^{\prime \prime}$ | Hexadecimal | Left | Variable | 1 | $\begin{aligned} & 256(\mathrm{DC}) \\ & 65,535(\mathrm{DS}) \end{aligned}$ |
| B | Binary | None | Binary digits | B' ${ }^{\prime}$ | Binary | Left | Variable | 1 | 256 |
| P | Packed decima | None | Decimal digits | $\mathrm{P}^{\prime}$ | Packed decimal | Left | Variable | 1 | 16 |
| z | Zoned decimal | None | Decimal digits | $z^{\prime} \cdot$ | Character | Left | Variable | 1 | 16 |
| H | Half word, fixed point | Half word | Decimal digits | $\mathrm{H}^{\prime}$ | Fixed-point binary | Left | 2 | 1 | 8 |
| F | Full word, fixed point | Full word | Decimal digits | $F^{\prime} \cdot$ | Fixed-point binary | Left | 4 | 1 | 8 |
| Y | Half-word address | Half word | Expression | Y() | Binary | Left | 2 | 1 | 2 |
| A | Full-word 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 symbol | V ( ) | Binary | Left | 4 | 3 | 4 |
| E | Full word, floating point | Full word | Decimal digits | $E^{\prime \prime}$ | Floatingpoint binary normalized | Right | 4 | 1 | 8 |
| D | Double word, floating point | Double word | Decimal digits | D' ${ }^{\prime}$ | Floatingpoint binary normalized | Right | 8 | 1 | 8 |

[^0]Following are DC-statement and DS-statement examples showing the use of the subfields, which must appear in the order stated and must not be separated by blanks.


## DC

### 5.1.1. Define Constant (DC)

The define constant ( $D C$ ) statement is processed by the assembler and the constant specification is translated into object code representing the required values. The maximum explicit length for a DC is 256 bytes. (See Table 5-1 for C, X, and B types.)

The following five examples show the use of the subfields in a DC statement.

| LABEL | $\triangle O P E R A T I O N \Delta$ | OPERAND |
| :--- | :--- | :--- |
| 1 | 10 | 16 |


| 1. | N4543 | DC |
| :--- | :--- | :--- |$\quad C^{\prime} 4543^{\prime} 1$

1. Four bytes containing:

| $F$ | 4 | $F$ | 5 | $F$ | 4 | $F$ | 3 |
| :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- |

N4543 has a length attribute of four bytes, the number of bytes assigned the value '4543'.
2. Eight bytes containing:


NAD also has a length attribute of four bytes, as called for by the value '4543', even though the duplication factor calls for two such fields of four bytes each.
3. Two bytes containing:


NAHS has a length attribute of two bytes, as specified by the length modifier, and only two bytes of storage are used. The digits 4,3 are ignored.
4. Four bytes containing:

| $F$ | 4 | $F$ | 5 | $F$ | 4 | $F$ | 5 |
| :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- |

WRD also has a length attribute of two bytes, as specified by the length modifier, but two fields of two bytes each are used because of the duplication factor of 2 . The digits 4, 3 are ignored.
5. Five bytes containing:


L591 has a 1 -byte length attribute, as specified by the length modifier of 1. There are five 1 -byte fields, as called for by the duplication factor. The digits 5, 4, 3 are ignored.

## DS

### 5.1.2. Define Storage (DS)

The define storage (DS) statement is processed by the assembler and the constant specification is translated into reserved storage. The maximum explicit length for a DS is 65,535 bytes. (See Table 5-1 for C and X types.) The following five examples show the use of the subfields in a DS statement. Only the number, not the content, of the bytes reserved by a DS statement is determined by the assembler.

| LABEL |  | $\triangle$ OPERATIONA |  | OPERAND |
| :---: | :---: | :---: | :---: | :---: |
|  |  | 10 | 16 |  |
| 1. | ILE | DS | C'4543 ${ }^{\prime}$ |  |
| 2. | AYAHC | DS | CL4 |  |
| 3. | DNOMYAR | DS | 2CL4 |  |
| 4. | REBEW | DS | 5C: |  |
|  | OREG | DS | $3 C^{\prime} \triangle$ NO. $\Delta^{\prime}$ |  |

1. ILE reserves a 4-byte field with a length attribute of 4 .
2. AYAHC produces the same result as line 1.
3. DNOMYAR reserves eight bytes composed of two fields of four bytes each. The length attribute of DNOMYAR is 4.
4. REBEW reserves five bytes of storage consisting of five fields of one byte each. The length attribute here is 1 .
5. OREG reserves 15 bytes of storage. The constant field defines a 5-byte field, and the duplication factor calls for three of these fields. The length attribute of OREG is 5 .

### 5.1.3. Duplication Factor

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. (See Table 5-2 for an example of the use of the zero duplication factor.) Note that, 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. (See 5.1.5.) The maximum value of the duplication factor is 256 .

Table 5-2. Zero Duplication Area Examples

| Address | Symbol | Operation | Operand |
| :---: | :---: | :---: | :---: |
| OOOD48 | WKAREA1 | DS | CL41 |
| 000 D 71 | WKAREA2 | DS | CL16 |
| 000D81 | WBE | DS | OCL121 |
| 000D81 | OUTPUT1 | DS | OCL121 |
| 000D81 | NEWAREA1 | DS | CL41 |
| 000DAA | NEWAREA2 | DS | CL80 |
| 000DFA | SGAW | DS | OCL 121 |
| 000DFA | INPUT1 | DS | OCL121 |
| 000DFA | COUNTS | DS | OCL3 |
| 000DFA | COUNT5 | DC | CL1'5' |
| 000DFB | COUNT12 | DC | CL2'12' |
| OOODFD |  | DS | CL118 |

The first work area shown, WKAREA1, has the hexadecimal location O000D48 and is 41 bytes long. The hexadecimal value of 41 is 29 , which is added in hexadecimal to produce the next hexadecimal location, O00D71. (See C.1.) The next areas WBE and OUTPUT1 show how we can assign different symbols to the same area. They do not take up storage space and so would have the same address of NEWAREA1, which you can see is 16 bytes away from the start of the last address. The hexadecimal value of 16 is 10 , making the address of NEWAREA1 O00D81. Now plus 80 bytes (hexadecimal 50) produces the address 000DFA.

### 5.1.4. Definition Type

The definition-type symbol is required for both DC and DS statements to determine the alignment (5.1.7), padding, truncation, storage form, and implied length. (See 5.2 and Table 5-1 for the characteristics of the 13 types used.)

### 5.1.5. Length Factor $\left(L_{n}\right)$

The length factor designates the explicit value of the length attribute of a field generated by a DS or DC statement. The letter $n$ represents either an unsigned decimal self-defining term or a positive absolute expression enclosed within parentheses. If any symbols are used in the expression, they must be previously defined. The length attribute of a field used in an assembler instruction determines the number of bytes generated for either that constant or reserved field. The maximum value of the length factor $(n)$ is 65,536 . Examples follow:

```
LABEL \triangleOPERATION\triangle
1 10 16
```

| 1. | WNS | DC | C'LENGTH ATTRIBUTE' |
| :--- | :--- | :--- | :--- |
| 2. | YAR | DS | CLI6 |
| 3. | WDR | DS | 2CLI6 |
| 4. | SGAW | DC | CLI6'LENGTH' |
| 5. | STOR | DC | CLI6 |

Examples 1 through 5 all have a length attribute of 16 bytes. The length factor is not required in example 1 because the constant specified is 16 bytes long. The length attribute of the receiving field in examples 2 through 5 is a vital element of the instruction. (See 12.12.)

When used, the length factor must follow the character $L$. The maximum and minimum values that may be explicitly specified are shown in Table 5-1 for all definition types. Constants that do not agree with the specified length are padded or truncated to the left or right, as shown in Table 5-1.

NOTE:
Boundary alignment is not provided when a length factor is specified.

### 5.1.6. Constant Specification

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.

Examples:

| 1. | YAR | DC |
| :--- | :--- | :--- |
| 2. | LG591 | DC |

This will produce 22 bytes as follows:

1. ENTER NUMBER ' $4 N$ ' HERE
2. ENTER THE NUMBER 51\&91

The constant may take the form of data or an address, as shown in Table 5-1.
$\frac{\text { Data Constant }}{\text { 'JUNE 15' }} \quad$ Address Constant

### 5.1.7. Alignment

Machine instructions are aligned on half-word boundaries; constants may be aligned on a half word, full word, double word, or no boundary. (See Table 5-1). When a length factor is specified in the DC or DS statement, no alignment is provided. A duplication factor of zero does not generate a constant or storage area but, for some types of constants, it forces a boundary alignment when no length is stated. This provides a method for obtaining boundary alignment before generating a constant that is not automatically aligned by the assembler. Bytes skipped to align constants are zero filled; bytes skipped to align storage areas are not.

### 5.2. DEFINITION TYPES

Data definition types generate absolute values or storage through the assembler interaction. There are 13 types, as shown in Table 5-1 and described in more detail in 5.2.1 through 5.2.12. (Also see 2.1.)

### 5.2.1. Character Constants (C)

The character C is used to specify character constants and can produce up to 256 bytes for a DC and 65,535 bytes for a DS statemnent. All of the 256 valid card punch combinations can be used, but only 48 or 64 characters are printable, depending on the print set available. When the length factor does not agree with the constant specification, padding or truncating takes place on the right. Padding takes place with blanks. (See 2.1 and 2.4.)

```
LABEL \triangleOPERATION\triangle OPERAND
1 10
OPERAND
```

1. 
2. TRUNCAT DC CLI ${ }^{\prime}$ CONSTANT'
CL5'CONSTANT'
3. NORMAL DC C'CONSTANT'
4. Produces: CONSTANT $\triangle \triangle$ (ten bytes)
5. Produces: CONST (five bytes)
6. Produces: CONSTANT (eight bytes)

A pair of ampersands is needed to specify a single ampersand constant. A pair of apostrophes is needed to specify a single apostrophe constant.

### 5.2.2. Hexadecimal Constants (X)

The character $X$ is used to specify hexadecimal constants and can produce up to 256 bytes for a DC and 65,535 bytes for a DS statement. Each byte contains two hexadecimal digits. When the length factor does not agree with the constant specification, padding or truncating takes place on the left. Padding takes place with hexadecimal zeros. (See 2.1 and 2.3.)


### 5.2.3. Binary Constants ( $B$ )

The character $B$ is used to specify binary constants and can produce up to 256 bytes. When the length factor does not agree with the constant specification, padding or truncating takes place on the left. Padding is done with binary zeros. The constant specification consists of only the numerals 0 and 1. (See 2.1 and 2.2.)


### 5.2.4. Packed Decimal Constants (P)

The character $P$ is used to specify signed packed decimal constants. It can produce up to 16 bytes. When the length factor does not agree with the constant specification, padding or truncating takes place on the left. Padding is done with hexadecimal zeros. The decimal constant is written as a signed or unsigned number. If unsigned, the number is assumed to be plus. A positive number is assembled with a hexadecimal C in the four least significant bits; a negative number has a $D$ in this location. The maximum of 16 bytes can contain 31 decimal digits plus the sign. (See 2.1 and 2.4.3.)


### 5.2.5. Zoned Decimal Constants $(Z)$

The character $Z$ is used to specify zoned decimal constants. It can produce up to 16 bytes. When the length factor does not agree with the constant specification, padding or truncating takes place on the left. Padding is done with zoned zeros (FO). A plus or unsigned number is assembled with a $C$ in the zone half of the rightmost byte; a negative number will have a $D$ in this location. (See 2.1.)

| 1. | PLUS | $D C$ | $Z^{\prime}+4543^{\prime}$ |
| :--- | :--- | :--- | :--- |
| 2. | NEG | $D C$ | $Z^{\prime}-4543^{\prime}$ |
| 3. | UNSIGNED | $D C$ | $Z^{\prime} 4543^{\prime}$ |
| 4. | PADDING | DC | $Z 5^{\prime}+4543^{\prime}$ |
| 5. | TRUNCAT | DC | $Z 3^{\prime}-4543^{\prime}$ |

1. Produces:


NOTE:
A zoned decimal number is also known as a signed unpacked number. (See 2.4.3.1 and 2.4.3.2.)

### 5.2.6. Half-Word Fixed-Point Constants (H)

The character H is used to specify half-word fixed-point constants. It can produce up to eight bytes. If no length factor is specified, the length attribute equals the implied length of two bytes. Padding or truncating takes place on the left. Padding is done with the sign of the value, binary 0 for a positive number and binary 1 for a negative number. The constant specification may not contain over five significant decimal digits nor a value greater than $+32767\left(2^{15}-1\right)$ or less than $-32768\left(-2^{15}\right)$. Unsigned values are treated as positive values. The data is aligned on a half-word boundary. (See 2.1, 2.5, and Section 10.)

| LABEL | $\triangle O P E R A T I O N \triangle$ | OPERAND |  |
| :--- | :--- | :--- | :--- |
| 1 | 10 | 16 |  |

1. 
2. 
3. 

3.1

|  |  |  |
| :--- | :--- | :--- |
| PLUS1 | DC | $H L I^{\prime}+57^{\prime}$ |
| PLUS2 | DC | $H^{\prime} 57^{\prime}$ |
| NEG1 | DC | $H L I^{\prime}-57^{\prime}$ |
| NEG2 | DC | $H^{\prime}-57^{\prime}$ |

1. Produces:

2. Produces:


### 5.2.7. Full-Word Fixed-Point Constants (F)

The character $F$ is used to specify full-word fixed-point constants. It can produce up to eight bytes. If no length factor is specified, the length attribute equals the implied length of four bytes. Padding or truncating takes place on the left. Padding is done with the sign of the value, binary 0 for a positive number and binary 1 for a negative number. The constant specification may not contain over 10 significant decimal digits nor a value greater than $+2,147,483,647\left(2^{31}-1\right)$ or less than $-2,147,483,648\left(-2^{31}\right)$. Unsigned values are treated as positive values. The data is aligned on a full-word boundary. (See 2.1, 2.5, and Section 10.)


1. Produces:

2. Produces:

3. Produces:
4. Produces:


### 5.2.8. Half-Word Address Constants $(\mathrm{Y})$

The character $Y$ is used to specify half-word address constants. It can produce up to two bytes. If no length factor is specified, the length attribute equals the implied length of two bytes. Padding or truncating takes place on the left. Padding is done with binary zeros. A length factor of one byte may be specified for absolute expressions only. The expression may be a positive or negative absolute value or a relocatable symbol representing the address of an instruction or item of data within the program. Alignment is on a half-word boundary. The maximum value that can be specified is $2^{15}-1(32,767)$.

| 1. | WRD |
| :--- | :--- |
| 2. | WBE |
| 3. | WMC |

DC
Y (EQUITY)
DC YLI (9)
3. WIMC DC $\quad Y(9)$

1. Produces a 2-byte area containing the address of the instruction EQUITY.

|  |  |  |  | 0000 |
| :--- | :--- | :--- | :--- | :--- |
| 2. | Produces: |  | 1001 |  | 1 byte

### 5.2.9. Full-Word Address Constants (A)

The character $A$ is used to specify full-word address constants. It can produce up to four bytes. If no length factor is specified, the length attribute equals the implied length of four bytes. Padding or truncating takes place on the left. Padding is done with binary zeros. Length factors of one or two bytes may be specified for positive or negative absolute values. The maximum value that can be specified is $2^{31}-1(2,147,483,647)$. Alignment is on a full-word boundary.

|  | $\begin{aligned} & \text { LABEL } \\ & { }_{1} \end{aligned}$ | $\triangle O P E R A T I O N \triangle$ |  |
| :---: | :---: | :---: | :---: |
|  |  | 10 | 16 |
| 1. | WRD | DC | A(VALLEY) |
| 2. | WBE | DC | ALI (9) |
| 3. | WMC | DC | AL2 (9) |


|  | $\begin{aligned} & \text { LABEL } \\ & { }_{1} \end{aligned}$ | $\triangle O P E R A T I O N \triangle$ |  |
| :---: | :---: | :---: | :---: |
|  |  | 10 | 16 |
| 1. | WRD | DC | A(VALLEY) |
| 2. | WBE | DC | ALI (9) |
| 3. | WMC | DC | AL2 (9) |

1. Produces a 4-byte area containing the address of the instruction VALLEY.
2. Produces:

OPERAND


### 5.2.10. Base and Displacement Constants (S)

The character $S$ is used to specify base and displacement constants. It can produce a 2 byte area. The only length factor that may be specified is 2 . No padding or truncating can take place. Alignment is on a half-word boundary when the length factor is not used. Neither negative values nor literals may be used. This instruction produces a 2-byte area, as follows.


The first four bits (half byte) contain the number of the base register used in this constant. The next 12 bits contain the value of the displacement to be added to the value in the register to produce the full address of the constant.

In the following example, in line 1, the value 5000 will be placed into register number 9 at execution time. (See 18.2 for the USING directive.) In line 2, assume the program has produced the address of 5025 to be assigned to the instruction called ELI, and this instruction is 25 bytes away from the area covered by register number 9 . The instruction CHAYA, line 3 , specifies the address of ELI, which is register number 9 (value 5000) plus a displacement of 25 bytes to give 5025. The instruction REBEW does not use an address symbol but explicitly states the displacement, 25 bytes, and register number 9 .

Examples:

| LABEL | $\triangle$ OPERATION $\triangle 16$ | OPERAND |
| :--- | :--- | :--- |


|  | START |  |
| :---: | :---: | :---: |
|  | - |  |
|  |  |  |
|  | USING | 5000,9 |
|  | - |  |
|  | - |  |
| ELI | DC | C'CONSTANT' |
|  | - |  |
|  | - |  |
| CHAYA | DC | S(ELI) |
| REBEW | DC | S(25(9)) |
|  | - |  |
|  | - |  |

The constants produced in lines 3 and 4 show the hexadecimal values of the base register and the displacement as follows:


### 5.2.11. External Address Constants (V)

The character $V$ is used to declare references to special external symbols. The constant must be used to reference an executable instruction which is external to the program. The reference symbol need not be identified by an EXTRN statement. (See 19.5.)

The only length factors that may be specified are 3 or 4 . If no length factor is used, the length attribute equals the implied length of four bytes and alignment will be on a fullword boundary.

Padding or truncating takes place on the left. Padding is done with hexadecimal zeros.
The specification of a symbol in the operand field of a type $V$ constant does not constitute a definition of the symbol.

Until the program containing the external symbol is linked to the program with the $V$ type constant, the value of the assembled constant is composed of hexadecimal zeros.

Example:


As the address value of this DC instruction (TRAVEL) is externally defined, the following constant is generated.
$\left.\begin{array}{|l|l|l:l|l|l|l:l|}\hline 0 & 0 & 0 & 0 & 0 & 1 & 0 & 0\end{array}\right) 0$

### 5.2.12. Floating-Point Constants (E and D)

The format of floating-point constants differs from the standard format of the DC statement (5.1) in that an additional subfield (the scale modifier) may appear. The format for floating-point constants is as follows:

| Label | DOPERATION $\Delta$ | OPERAND |
| :---: | :--- | :---: |
| $[$ symbol $]$ | DC | $[d] t\left[L_{n}\right][S+n]^{\prime} c[E \pm n]^{\prime}$ |

where:
d
Is the duplication factor.
t
Is the definition type ( E , full word; D , double word).
$L_{n}$
Is the explicit length factor in decimal.
$\mathbf{S}+\mathbf{n}$
Is the scale modifier.
' $\mathrm{c}[\mathrm{E} \pm \mathrm{n}]$ '
Is the constant specification with optional exponent.

The subfields must be written in the order given. The $d, t$, and Ln subfields are discussed in 5.1. The scale modifier 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.

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, fullword 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.

A floating-point number is written as a decimal number. It can be an integer (110), a fraction ( 0.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.

The machine representation of the constant consists of a hexadecimal fraction (mantissa) and a hexadecimal exponent (characteristic). The decimal 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 shown in Figure 5-1.


Figure 5-1. Floating-Point Number Formats

Example:
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 . The decimal number 255 will generate the floating-point number 42FF0000.

| Label | $\triangle$ OPERATION $\triangle$ |  |
| :---: | :--- | :--- |
| [symbol] | DC | E' $^{\prime} 255^{\prime}$ |

Decimal $255=$ the fraction $\times 16$. The floating-point number shown in hexadecimal form is 42FF0000.

In this example:
$\mathrm{n}=$ hexadecimal 42 (decimal value 66) fraction $=$. FFOOOO (decimal value .9961 from the table in C.2). Therefore, 42FF0000 equals:

|  | $.9961 \times 16^{66-64}$ |
| :--- | :--- |
| or | $.9961 \times 16^{2}$ |
| or | $.9961 \times 256$ |
| or | 255 |

If scaling is not specified, the fraction is hexadecimally normalized; that is, all leading hexadecimal zeros are removed, and the characteristic is adjusted by 1 for each zero removed. Rounding is then performed, and the number is assembled into the field as specified by the explicit or implicit length. Negative fractions are carried, not in two's complement, but in true representation.

The scale modifier must be a positive value from 0 to 14 . This modifier specifies the number of hexadecimal positions (four bits) the number is shifted to the right. Scaling provides an unnormalized floating-point number. The characteristic is adjusted to reflect the number of hexadecimal positions the number has been shifted. If any hexadecimal positions are lost, rounding occurs in the rightmost hexadecimal position retained.

## Examples:

Normalized number, value 255 .


Unnormalized number, value 255.


Unnormalized number, value 255 .


See 2.6, Section 11, and Appendix C.

### 5.3. LITERALS

A literal is a representation of data within a source code statement and can be coded in the sending field of either operand. A literal is simply a constant coded with an equal sign followed by a type code and a nominal value enclosed within single quotation marks.

The method of describing and specifying a constant as a literal is almost identical to the method of specifying it in the operand field of a DC statement. When a literal is assembled, the data is stored in a "literal pool" which is a special area in main storage where all literals are placed. The address of that storage field in the literal pool is then placed in the operand field of the assembled statement.

If two identical literals occur within one literal pool, only the first literal is stored.
The permissible uses of literals are:

- Any type of data can be used to specify a literal.
- Only one reference to the same literal in a coding statement can be made.
- A literal is always in the sending field of an operand.
- Literals are relocatable because the address (not the literal itself) is assembled in the coding statement.
- Literals can be self-defining terms which are recognized by the absence of the equal sign, also referred to as immediates.
- Duplication factors can be used in the specification of literals and are expressed only by unsigned decimal values except zero.
- Length attributes can be used in the specification of literals and are expressed only by unsigned decimal values.

The nonpermissible uses of literals are:

- A literal can never be used in the receiving field of an operand.
- A literal cannot be combined with other terms.
- It cannot be specified within the parenthesis of an address constant.
- It cannot be specified in a shift instruction, or an I/O instruction (SIO).
- A literal cannot have an explicit base or an explicit index.
- Absolute (with all terms previously defined), relocatable, or complex relocatable expressions cannot be used as either duplication factors or length attributes.


## Example:



On line 5 of the sample program, a literal is used in the sending field of operand 2. The equal sign is used followed by the type code (which in this case is F, full word) and the nominal value enclosed in single quotation marks. Note that the object code produced when the literal is assembled is the address (00020) of the field in the literal pool where that literal was placed. Line 18, under object code, shows the literal actually generated.

## 6. Symbol Definitions

Byte locations in main storage are numbered consecutively starting with zero. Each number is considered the address of the byte of data stored at that location. A group of consecutive bytes is addressed by the leftmost byte. A symbol appearing in the label field of a statement defining an instruction, constant, or storage area is assigned the address value of the first byte of the source statement with which the symbol is associated. The following rules apply to the general use of symbols.

- 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

Example of valid label field symbols:

| LABEL | $\triangle$ OPERATION |  |
| :--- | :--- | :--- |
| 1 | 10 | 16 |$\quad$ OPERAND


|  | DC | $P^{\prime} 4 \varnothing 69^{\prime}$ |
| :--- | :--- | :--- |
| N4543 | DS | PL4 |
| DNOMYARD | DC | $C^{\prime} 5 \not \varnothing^{\prime}$ |
| CASH \$OUT | BALR | R5, |

Examples of invalid symbols:

| LABEL | $\triangle$ OPERATION $\triangle$ | OPERAND |
| :--- | :--- | :--- |
| 1 | 10 | 16 |


| 1. | EQUITY DC | P'4ø2' |
| :--- | :--- | :--- |
| 2. | 4543 | DS |
| 3. | READ ONE PACK | OL4 |
| 4. | CONSISISTORY DC | C' $8 \varnothing^{\prime}$ |

1. Invalid because symbol does not start in column 1
2. Invalid because symbol does not start with an alphabetic character or special letter
3. Invalid because symbol contains a special character (space)
4. Invalid because symbol is longer than eight characters

### 6.1. EQUIVALENT SYMBOLS

To make a program more meaningful, the programmer may use more than one symbol to represent the same value or location. The same output area could be called NURECORD (in one place) and OUTPUT1 in another part of the program. The EOU directive (Section 16) can be used, as shown in this section, to equate these symbols. An EQU may be used to equate any symbol to any other symbol or to a value. Only the operands may declare expressions.

| NURECORD | EQU | OUTPUTI |
| :--- | :--- | :--- |
| RQ | EQU | $\emptyset$ |
| RI | EQU | 1 |
| R2 | EQU | 2 |
| R3 | EQU | 3 |
| $\cdot$ |  | $\cdot$ |
| - |  | $\cdot$ |
| R12 | EQU | 12 |
| R13 | EQU | 13 |
| R14 | EQU | 14 |
| R15 | EQU | 15 |

After the EQU directive, a register instruction could be written in any of the following ways:

| LABEL | $\triangle O P E R A T I O N \Delta$ | OPERAND |
| :--- | :--- | :--- |
| 1 | 10 | 16 |


| ADD | AR | R1, R2 |
| :--- | :--- | :--- |
| LOAD | LA | $5,2(5)$ |

LOAD LA R5,2(R5)
MOVE MVC WKAREA,REC
MOVE MVC $15(7,9), 5(10)$
MOVE MVC 15(7,R9),5(R1ø)
NOTE:
Throughout, the register notations (RO through R15) represent the registers 0 through 15.

### 6.2. SYMBOL APPLICATIONS

Symbols are used not only to identify storage areas and constants but also to locate instructions in the program. In the following example, the branch instruction with the symbol RETURN calls for a branch to the location CONSIS32 under certain conditions. The branch instruction called TRAVEL branches around the nonexecutable DC constants to the location SQUARE.


```
LABEL \triangleOPERATION\triangle
1 10 16
```

OPERAND

| RETURN | BC | 7,CONSIS32 |
| :---: | :---: | :---: |
|  | - |  |
|  | - |  |
| MASTER | CLC | WEEKS52,=P'52' |
|  | . |  |
|  | - |  |
|  | EOJ |  |
|  | EOJ |  |
| R2 | EQU | 2 |
| R3 | EQU | 3 |
| R4 | EQU | 4 |
| Rebew | DC | $\mathrm{P}^{\prime}+52^{\prime}$ |
| WEEKS52 | EQU | REBEW |
| VALLEY | DS | CL32 |
| CONSISTO | DS | XL32 |
|  | END | BEGIN |

The EQU directives show how to use the symbol WEEKS52 for REBEW; also RO,R2,R3, and R4 for registers $0,2,3$, and 4.

Through the extensive use of symbols and the assembly listing cross-reference, you can trace every use of a data area or instruction routine. (See 28.5.)

PART 3. BAL APPLICATION INSTRUCTIONS

# 7. Introduction to Application Instructions 

### 7.1. INSTRUCTION AND FORMAT CONVENTIONS

Certain conventions have been adopted in this manual for specifying instruction, directive, macro, proc, and control-statement formats. The following paragraphs describe these conventions.

There are six types of assembler application instructions:
RR — Register-to-register
RX - Register-to-storage-indexed or storage-to-register-indexed
RS - Register-to-storage-nonindexed or storage-to-register-nonindexed
SI - Storage immediate
SS - Storage-to-storage (Type SS1)
SS - Storage-to-storage (Type SS2)
Figure 7-1 illustrates the source code and object code formats for each of these instruction types. (Also see Section 4.)

notes:
(1) The RR instruction has three other forms: [symboll opcode 1 , for the SVC instruction: [symbol] opcode $r$, for the SPM instruction; and
[symbol] opcode $\mathrm{m}_{1}, \mathrm{r}_{2}$ for the BCR instruction.
(2) The RX instruction BC is
written in the form:
Isymboll opcode $m_{1}, d_{2}\left(x_{2}, b_{2}\right)$

Figure 7-1. Instruction Formats (Part 1 of 2)

| Characters | Meaning |
| :---: | :---: |
| OPCODE | The application instruction operation code. |
| ${ }_{1}$ | The number of the general register containing operand 1 |
| $r_{2}$ | The number of the general register containing operand 2 |
| $r_{3}$ | The number of the general register containing operand 3 |
| $x_{2}$ | The number of the general register containing an index number for operand 2 of the $\mathbf{R X}$ instruction |
| $\mathrm{i}_{1}$ | The immediate data used as operand 1 of the SVC instruction |
| $\mathrm{i}_{2}$ | The immediate data used as operand 2 of an Sl instruction |
| 1 | The length of the operands as stated in source code* |
| 11 | The length of operand 1 as stated in source code* |
| $I_{2}$ | The length of operand 2 as stated in source code* |
| $\mathrm{b}_{1}$ | The number of the general register containing the base address for operand 1 |
| $b_{2}$ | The number of the general register containing the base address for operand 2 |
| $d_{1}$ | The displacement for the base address of operand 1 |
| $\mathrm{d}_{2}$ | The displacement for the base address of operand 2 |
| $\mathrm{m}_{1}$ | The mask used as operand 1 |
| op 1 | Operand 1 |
| $\mathrm{op}_{2}$ | Operand 2 |
| $\mathrm{op}_{3}$ | Operand 3 |
| $\mathrm{s}_{1}$ | The symbol used to identify operand 1 in the implicit format |
| $\mathrm{s}_{2}$ | The symbol used to identify operand 2 in the implicit format |

*In source code, the length you specify is 1 greater than the object code length. The reason for this is that 0 is the first length count, not 1 . For example, I can address a maximum length of 256 , but in actuality, I get 0 through 255 bytes. The assembler makes a reduction of 1 in the length when converting source code to object code.

Figure 7-1. Instruction Formats (Part 2 of 2)

An instruction is an executable statement for operations involving data. The assembler instructions are two, four, or six bytes in length. (See Figure 7-1.) In a 2-byte (RR) instruction, the registers are referenced for both operands. A 4-byte (RS) instruction references a register for the first operand and main storage for the second operand. A 4byte (RX) instruction references registers for the first and second operands and main storage for the third operand. A 4-byte immediate operand (SI) instruction references main storage for the first operand and immediate data for the second operand. A 6-byte (SS) instruction references main storage for both operands.

NOTE:

The implied length field may be applicable with the SS1 and SS2 type instructions. If no length is specified in an SS1 type instruction, the length attribute of the first operand is assembled into the length field of the instruction. The length attribute of an operand is the length attribute of the expression used to define the storage location. The SS2 type instruction contains a length field for each operand; however, neither, either, or both length fields may be implied. In every case, the assembler puts the operand lengths, implied or specified, into the length fields.

The following are examples of implied and explicitly stated lengths.



Instruction 1 (PAD) packs all seven digits and the sign of operand 2 (NUMBER7) into four bytes of operand 1 (NUMBER12), then zero fills the remaining eight bytes of the implied field of 12 bytes. Instruction 2 (FILLUP) packs all seven digits and the sign of operand 2 into the explicit four bytes of operand 1 . Instruction 3 (TRUNCATE) packs crit; itic explicitly stated three digits and the sign of operand 2 into the explicit four bytes of operand 1. Labeled instructions themselves are assigned implied lengths based on instruction type.

There are six basic ways to explain how an assembler application instruction is written: the implicit format, the implicit source code example, the explicit format, the explicit source code example, the object code format, and the object code example. The first four methods are shown for each instruction in this part of the user guide as the subject of object code formats covered in 4.3.1 and are discussed again in assembly listings (Part 6). The following shows how the move character instruction is written.

- Implicit source code:

Format:

| Label | पOPERATION $\triangle$ |  |
| :---: | :--- | :--- |
| [symbol] | MVC | $\mathrm{s}_{1}(\mathrm{I}), \mathrm{s}_{2}$ |

Example:

| MOVE5 | MVC | LODGE,MASTER |
| :--- | :--- | :--- |
| MOVE32 | MVC | LODGE (32),MASTER |

- Explicit source code:

Format:

| LABEL | $\triangle$ OPERATION $\Delta$ |  |
| :---: | :--- | :--- |
| OSymbol] | MVC | $d_{1}\left(1, b_{1}\right), d_{2}\left(b_{2}\right)$ |

Example:


- Object code:

Format:

| 0 opcode | 7 | 8 | $I_{1}$ | 15 | 16 | $\mathrm{b}_{1}$ | 19 | 20 | $d_{1}$ | 31 |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |



Example as shown on an assembly listing:
000DF5 D2 1F 20F1 30FC

### 7.2. EXPLICIT FORMS

The first line is how the explicit format is expressed, and the second line is an example of how you might write the explicit source code form of the add instruction.

Explicit Format:

| Label | $\triangle$ OPERATION $\triangle$ | OPERAND |
| :---: | :---: | :---: |
| [symbol] | A | $\mathrm{r}_{1}, \mathrm{~d}_{2}\left(\mathrm{x}_{2}, \mathrm{~b}_{2}\right)$ |
| ADDREC | A | R2,32(R3,R5) |

### 7.3. IMPLICIT FORMS

The first line is how the implicit format is expressed, with the following one or more lines being examples of how you might write the implicit source code forms of the add instruction using symbols to represent registers and data areas.

Implicit Format:

| LABEL | $\triangle$ OPERATION $\triangle$ | OPERAND |
| :--- | :--- | :--- |
| [symbol] | A | $r_{1}, s_{2}\left(x_{2}\right)$ |
| ADDFOR | A | R2, PAYSUM |
| ADDREG | A | R2, PAYSUM(R3) |

### 7.4. DEFINITIONS OF FORMAT TERMS

Figure 7-1 explains all the terms used in describing the explicit and implicit forms of the instructions. The following additional explanations will help you to understand the implicit and explicit forms of programming coding.

- The general registers $r_{1}, r_{2}$, or $r_{3}$ are shown in the R0 through R15 form.
- The index register $x_{2}$ and the base registers $b_{1}$ and $b_{2}$ are also shown in the RO through R15 form.
- The terms $s_{1}$ and $s_{2}$ represent the use of a symbol (4.2.1 and Section 6) in the first or second operand.
- The displacement $d_{1}$ or $d_{2}$ is a decimal value which is combined with the value in some base register.
- A checkoff table is included for each applicable instruction in the text. Explanations of the program exceptions are provided in Appendix D.


## 8. Branching Instructions

### 8.1. USE OF BRANCHING INSTRUCTIONS

Branching instructions are used to alter the normally sequential execution of instructions by branching out of sequence to link to a subroutine, make a decision, or control looping. The operand 2 field of each branching instruction refers to the address (branch to) of the instruction to be executed immediately after the branching instruction. The branch-to address in operand 2 is stored in bits $40-63$ of the current program status word (PSW) (Figure 8-1). The PSW is a double word containing the address of the next instruction and various other control fields. In general, the PSW is used to control instruction sequencing and to hold and indicate the status of the system in relation to the program currently being executed. (See the processor programmer reference, UP-8052 (current version) for a complete description of the PSW.)


Figure 8-1. Program Status Word Diagram

While the program is executing, it utilizes the PSW (called the current PSW), which is stored in the supervisor portion of the operating system. Before a branch out of the sequence of the program to a new location, the present location of the program is stored in the PSW. That PSW (called the old PSW) is saved, and the program uses a new PSW (current) to keep track of pertinent program information. In other words, the old PSW holds the place in the program if you want to return to where you were before branching to a routine or instruction in another area, and the current PSW keeps track of the running program regardless of where you branched to.

There are additional branching instructions, which are part of the featured instruction set (Section 14). You can use the featured instructions only if the processor has the control feature.

For an explanation of the checkoff table exceptions, see Appendix D.

### 8.2. EXTENDED MNEMONIC CODES



The extended mnemonic codes are used like the branch on condition (8.5) instruction (checkoff table for BC instruction is shown above). Extended mnemonics are the shorthand version of the branch on condition ( BC ) instruction. They are easy to use because you do not need to remember the decimal value that is associated with the operand 1 mask of the branch on condition instruction. You merely remember the mnemonic. The extended mnemonics create the mask value, which tests the condition code. If the specific condition or conditions you want to branch on exist, a branch is made to the address specified in operand 2.

Before a branch is made, the address of the running program is saved, thus enabling you to return to that point if desired. It is a good idea to familiarize yourself with the branch on condition instruction and Table 8-1 before you use the extended mnemonics.

Table 8-1 is a listing of the extended mnemonic codes. The hexadecimal operation codes (with mask) and functions, categorized by instruction type, are grouped according to use. Also included are the branch on condition ( BC ) instruction equivalents. An example of a hand-written coding form follows.

Example:


1. The compare decimal (CP) instruction compares the packed decimal contents of $A$ against the packed decimal contents of B . Based on the results, the condition code in the PSW is set to 1 (operand $1<$ operand 2 ).
2. The next sequential instruction executed is branch if equal (BE). The mask (8) tests for condition code 0 (operand $1=$ operand 2 ). Since the condition is not 0 , no branch is made, and the next sequential instruction is executed.
3. Since no branch was made, the next sequential instruction executed is branch if low (BL). The mask (4) tests for condition code 1 (operand $1<$ operand 2). Since the condition code is 1 , a branch is made to the operand 2 address (LOW). In this example, LOW is the address of an add decimal instruction, which is the instruction executed after the BL instruction.

Note that the next sequential instruction is branch if high (BH), but it is not executed after the BL instruction.

Table 8-1. Extended Mnemonics and Functions (Part 1 of 2)

| RR-Type Instructions |  | RX-Type Instructions |  | BC Equivalent | Function |
| :---: | :---: | :---: | :---: | :---: | :---: |
| Mnemonic Code | Hexadecimal Operation Code/m 1 | Mnemonic Code | Hexadecimal Operation Code/m1 | Explicit Form |  |
| Used to Branch Around Nonexecutable Assembler Instructions and Directives |  |  |  |  |  |
| BR <br> NOPR | $\begin{aligned} & 07 \mathrm{~F} \\ & 070 \\ & - \\ & - \end{aligned}$ | B <br> NOP | $\begin{aligned} & - \\ & - \\ & 47 \mathrm{~F} \\ & 470 \end{aligned}$ | BCR $15, r_{2}$ <br> BCR $0, r_{2}$ <br> BC $15, d_{2}\left(x_{2}, b_{2}\right)$ <br> BC $0, d_{2}\left(x_{2}, b_{2}\right)$ | Branch unconditionally No operation Branch unconditionally No operation |

Table 8-1. Extended Mnemonics and Functions (Part 2 of 2)

| RR-Type Instructions |  | RX-Type Instructions |  | BC Equivalent | Function |
| :---: | :---: | :---: | :---: | :---: | :---: |
| Mnemonic Code | Hexadecimal Operation Code/m 1 | Mnemonic Code | Hexadecimal Operation Code/m1 | Explicit Form |  |
| Used After Comparison Instructions |  |  |  |  |  |
| BHR <br> BLR <br> BER <br> BNHR <br> BNLR <br> BNER | 072 <br> 074 <br> 078 <br> 07 D <br> 07 B <br> 077 | BH <br> BL <br> BE <br> BNH <br> BNL <br> BNE | 472 <br> 474 <br> 478 <br> 47 D <br> 47 B <br> 477 | $B C$ $2, \mathrm{~d}_{2}\left(\mathrm{x}_{2}, \mathrm{~b}_{2}\right)$ <br> $B C$ $4, \mathrm{~d}_{2}\left(\mathrm{x}_{2}, \mathrm{~b}_{2}\right)$ <br> $B C$ $8, \mathrm{~d}_{2}\left(\mathrm{x}_{2}, \mathrm{~b}_{2}\right)$ <br> $B C$ $13, \mathrm{~d}_{2}\left(\mathrm{x}_{2}, \mathrm{~b}_{2}\right)$ <br> $B C$ $11, \mathrm{~d}_{2}\left(\mathrm{x}_{2}, \mathrm{~b}_{2}\right)$ <br> $B C$ $7, \mathrm{~d}_{2}\left(\mathrm{x}_{2}, \mathrm{~b}_{2}\right)$ | Branch if high <br> Branch if low <br> Branch if equal <br> Branch if not high <br> Branch if not low <br> Branch if not equal |
| Used After Test-Under-Mask Instructions |  |  |  |  |  |
| BOR <br> BZR <br> BMR <br> BNOR <br> BNZR <br> BNMR | 071 <br> 078 <br> 074 <br> 07 E <br> 077 <br> 07 B | B0 <br> BZ <br> BM <br> BNO <br> BNZ <br> BNM | 471 <br> 478 <br> 474 <br> 47 E <br> 477 <br> 47 B | BC $1, d_{2}\left(x_{2}, b_{2}\right)$ <br> BC $8, d_{2}\left(x_{2}, b_{2}\right)$ <br> BC $4, d_{2}\left(x_{2}, b_{2}\right)$ <br> $B C$ $14, d_{2}\left(x_{2}, b_{2}\right)$ <br> BC $7, \mathrm{~d}_{2}\left(x_{2}, \mathrm{~b}_{2}\right)$ <br> BC $11, d_{2}\left(x_{2}, \mathrm{~b}_{2}\right)$ | Branch if all ones <br> Branch if all zeros <br> Branch if mixed <br> Branch if not all ones <br> Branch if not all zeros <br> Branch if not mixed |
| Used After Arithmetic Instructions |  |  |  |  |  |
| BOR <br> BZR <br> BMR <br> BPR <br> BNOR <br> BNZR <br> BNMR <br> BNPR | 071 <br> 078 <br> 074 <br> 072 <br> 07 E <br> 077 <br> 07 B <br> 07 D | BO <br> BZ <br> BM <br> BP <br> BNO <br> BNZ <br> BNM <br> BNP | 471 <br> 478 <br> 474 <br> 472 <br> 47 E <br> 477 <br> 47 B <br> 47 D | BC $1, d_{2}\left(x_{2}, b_{2}\right)$ <br> $B C$ $8, d_{2}\left(x_{2}, b_{2}\right)$ <br> $B C$ $4, d_{2}\left(x_{2}, b_{2}\right)$ <br> $B C$ $2, d_{2}\left(x_{2}, b_{2}\right)$ <br> $B C$ $14, d_{2}\left(x_{2}, b_{2}\right)$ <br> $B C$ $7, d_{2}\left(x_{2}, b_{2}\right)$ <br> $B C$ $11, d_{2}\left(x_{2}, b_{2}\right)$ <br> $B C$ $13, d_{2}\left(x_{2}, b_{2}\right)$ | Branch if overflow <br> Branch if zero <br> Branch if minus <br> Branch if positive <br> Branch if not overflow <br> Branch if not zero <br> Branch if not minus <br> Branch if not positive |

### 8.3. BRANCH AND STORE (BAS, BASR)



| Possible Program Exceptions |  |
| :--- | :--- |
| $\square$ ADDRESSING | $\square$ PROTECTION |
| $\square$ DATA (INVALIDSIGN/DIGIT) | $\square$ SIGNIFICANCE |
| $\square$ DECIMAL DIVIDE | $\square$ SPECIFICATION: |
| $\square$ DECIMAL OVERFLOW | $\square$ |
| $\square$ EXECUTE | $\square$ | OP A FLOATING-POINT REGISTER 1 NOT ON HALF-WORD BOUNDARY

The branch and store (BAS, BASR) instructions do not exist in the native mode set and are used only when operating in the 360/20 compatibility mode. They operate in the same way the branch and link instructions (8.4) operate (i.e., operand 1 contains the address of the program after executing the branching instruction but before executing the instruction you branched to). Operand 2 contains the address of the instruction executed immediately after the branching (BAS, BASR) instruction.

## BAL

## BALR

### 8.4. BRANCH AND LINK (BAL, BALR)

| General |  |  |  | Possible Program Exceptions |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| OPCODE |  | FORMAT TYPE | OBJECT <br> INST. <br> LGTH. <br> (BYTES) | ADDRESSINGDATA (INVALIDSIGN/DIGIT)DECIMAL DIVIDEDECIMAL OVERFLOWEXECUTEEXPONENT OVERFLOWEXPONENT UNDERFLOWFIXED-POINT DIVIDEFIXED-POINT OVERFLOWFLOATING-POINT DIVIDEOPERATION | PROTECTION SIGNIFICANCE SPECIFICATION: NOT A FLOATING-POINT REGISTER <br> OP 1 NOT ON HALF-WORD BOUNDARY <br> OP 2 NOT ON HALF-WORD BOUNDARY <br> OP 2 NOT ON FULL-WORD BOUNDARY <br> OP 2 NOT ON DOUBLE-WORD <br> BOUNDARY <br> OP 1 NOT EVEN NUMBERED REGISTER <br> OP 1 NOT ODD NUMBERED REGISTER <br> NONE |  |
| MNEM. | HEX. |  |  |  |  |  |
| BAL | 45 | RX | 4 |  |  |  |
| BALR | 05 | RR | 2 |  |  |  |
| Condition Codes |  |  |  |  |  |  |
| IF RESULT $=0$, SET TO O if RESULT<0, SET TO 1IF RESULT $>0$ O, SET TO 2IF OVERFLOW, SET TO 3 UNCHANGED |  |  |  |  |  |  |

The branch and link (BAL and BALR) instructions alter the normally sequential execution of instructions by branching to an address you specify in operand 2. The instruction located at that address is the next instruction executed after the branch and link instruction. Before the branch is made, the address of the next sequential instruction (current location) is saved in the operand 1 register to enable you to return to the location where you were before branching.

## Explicit Format:

| LABEL | $\triangle$ OPERATION $\triangle$ |  |
| :--- | :--- | :--- |
| OPERAND |  |  |
| [symbol] | BAL | $r_{1}, d_{2}\left(x_{2}, b_{2}\right)$ |
| [symbol] | BALR | $r_{1}, r_{2}$ |

Implicit Format:

| LABEL | $\triangle$ OPERATION $\triangle$ |  |
| :--- | :--- | :--- |
| [symbol] | BAL | $r_{1}, s_{2}\left(x_{2}\right)$ |

Example 1 (BAL):

|  | $\begin{aligned} & \text { LABEL } \\ & 1 \end{aligned}$ | $\triangle O P E R A T I O N \triangle$ |  | OPERAND |
| :---: | :---: | :---: | :---: | :---: |
|  |  | 10 | 16 |  |
| 1. |  | BAL | 6, BRANCHTO |  |
| 2. | NEXTSEQ | AP | A, B |  |
| 3. | BRANCHTO | CP | A, B |  |
|  | A | DC | P'654' |  |
|  | B | DC | $P^{\prime} 123^{\prime}$ |  |

1. In this coding example, the BAL instruction alters the sequential execution of instructions by causing a branch to an area in main storage labeled BRANCHTO. Before the branch, the address of the next sequential instruction is stored in register 6 (location of NEXTSEQ).
2. Since a branch took place, the normally sequential execution of the add decimal (AP) instruction (NEXTSEQ) is skipped.
3. This compare decimal (CP) instruction is processed immediately following the BAL instruction, since its label (BRANCHTO) is the branch-to address (operand 2) of the BAL instruction.

Example 2 (BALR):

```
2.
```



1. This load address (LA) instruction puts the address of an instruction labeled ROUTINE (CP) into register 4.
2. The BALR instruction stores the address NEXTSEO in register 6, then branches to the branch address in register 4 . Since register 4 is the address of ROUTINE, the instruction following the BALR instruction is compare decimal (CP).

## Operational Considerations:

- You may specify any of the general registers ( 0 through 15 ) as operand 1 in both the BAL and BALR instructions, and any of these registers as operand 2 of the BALR instruction.
- The address of the instruction following the BAL or BALR instruction is placed in the operand 1 register. Then the branch to the address specified in operand 2 is made.
- If you specify 0 as operand 2 of a BALR instruction, it means you are not specifying a branch-to address, and, therefore, no branch takes place. The instruction executed after the BALR is the next instruction in sequence.


### 8.4.1. Use of the BALR Instruction in Base Register Assignment

The BALR instruction is used in conjunction with the USING directive (see 18.2) to assign a base address to a register. This address becomes the starting address of your program. The BALR instruction and the USING directive must be coded in the following order:

| LABEL | $\triangle O P E R A T I O H A$ | OPERAND |  |
| :--- | :--- | :--- | :--- |
|  | 10 | 16 |  |
| BASEREG | START | $\emptyset$ |  |
| BEGIN | BALR | $3, \emptyset$ |  |
|  | USING | $\because, 3$ |  |
|  | OPEN | INFILE,OUTFILE |  |
| READ | GET | INFILE |  |

The BALR instruction in this example stores the address of the next sequential instruction (OPEN) in register 3. No branch takes place since 0 is specified as operand 2. Logically, the address of the USING directive should be stored in register 3, since that is the next instruction. However, USING is a directive and not an executable instruction. Directives are information to the assembler only. They do not generate any object code nor increase the location counter. Therefore, OPEN is the next executable instruction following the BALR instruction.

The USING directive tells the assembler that register 3 is going to be used as the base register for this program. Register 3 can accommodate a program up to 4096 bytes in length. If your program is larger than this, additional base registers can be assigned. (See 18.2.) Operand 1 tells the assembler at what point in your program your base register should start being used. The asterisk (*) means "start now". So, operand 1 indicates
starting now, all addresses of the following instructions will use the register specified by operand 2 (in this case, 3) as the base register.

In the following printout example, an LA instruction (line 3) is coded after the BALR instruction, causing an addressability error. The BALR instruction (line 2) stores the address of the next sequential instruction (LA) in register 3. No branch takes place since 0 is specified as the operand 2 register. At location counter 000002, no object code was generated for the LA instruction because the assembler does not assemble an erroneous instruction. It does, however, increase the location counter by the number of bytes that that instruction occupies. Now, register 3 contains the address of the LA instruction at 000002 but the USING directive (line 4) tells the assembler that starting at location counter 000006, all succeeding instructions will use register 3 as the base register. The USING directive assumes that register 3 contains the address at location counter 000006 but in reality contains the address at location counter 000002. So, all the addresses of every instruction and label in this program will be calculated as being four bytes more than its actual location. Therefore, the BALR instruction and USING directive must always refer to the same address so that the base and displacement values can be accurately calculated.

Example:


## BC

BCR

### 8.5. BRANCH ON CONDITION (BC, BCR)



The branch on condition ( $B C$ and $B C R$ ) instructions change program sequence based on the condition code setting of the PSW. You specify in the operand 1 mask a decimal value that tests the condition code to see whether the branch-causing condition exists. If the condition of the branch does exist, a branch is made to the operand 2 address you specify in the branch on condition instruction. If the condition of the branch does not exist, no branch takes place, and the next sequential instruction is executed.

## Explicit Format:

| LABEL | $\triangle$ OPERATION $\triangle$ |  |
| :--- | :--- | :--- |
| [symbol] | BC | $\mathrm{m}_{1}, \mathrm{~d}_{2}\left(\mathrm{x}_{2}, \mathrm{~b}_{2}\right)$ |
| [symbol] | BCR | $\mathrm{m}_{1}, \mathrm{r}_{2}$ |

Implicit Format:

| LABEL | $\triangle$ OPERATION $\triangle$ |  |
| :--- | :--- | :--- |
| [symbol] | BC | $\mathrm{m}_{1}, \mathrm{~s}_{2}\left(\mathrm{x}_{2}\right)$ |
| [symbol] | BCR | $\mathrm{m}_{1}, \mathrm{r}_{2}$ |

The condition code, bits $34-35$ of the PSW, reflects the result of an instruction executed prior to the branch on condition instruction. There are four possible condition code settings:

If result $=0$, set to 0 .
If result $<0$, set to 1 .
If result $>0$, set to 2 .
Hf overflow, set to 3 .

The decimal values that can be specified in the operand 1 mask are 0 through 15, each of which has a 4-bit binary representation.

- The decimal value $8(1000)$ tests for condition code 0 .
- The decimal value $4(0100)$ tests for condition code 1 .
- The decimal value $2(0010)$ tests for condition code 2.
- The decimal value 1 (0001) tests for condition code 3.

Note that only one bit is set for each condition. When more than one bit is set in the 4-bit binary configuration, it is possible to test for multiple conditions.


The decimal value 10 tests for:
(1) condition code 0 (result is equal to zero) and
(2) condition code 2 (result is greater than zero)

Table 8-2 lists the 16 values and each condition code it tests.

Table 8-2. Operand 1 Mask Combinations

| Mask |  | Possible Combinations of Condition Codes | Branches on Condition Code | Results <br> Causing <br> Branch |
| :---: | :---: | :---: | :---: | :---: |
| Decimal Value | Binary Value |  |  |  |
| 0 | 0000 | * | no operation | None |
| 1 | 0001 | $1=1$ | 3 | Overflow |
| 2 | 0010 | $2=2$ | 2 | $>0$ |
| 3 | 0011 | $3=2+1$ | 2.3 | $>0$ or overflow |
| 4 | 0100 | $4=4$ | 1 | $<0$ |
| 5 | 0101 | $5=4+1$ | 1,3 | <0 or overflow |
| 6 | 0110 | $6=4+2$ | 1,2 | $\neq 0$ |
| 7 | 0111 | $7=4+2+1$ | 1,2,3 | $\neq 0$ or overflow |
| 8 | 1000 | $8=8$ | 0 | $=0$ |
| 9 | 1001 | $9=8+1$ | 0,3 | = 0 or overflow |
| 10 | 1010 | $10=8+2$ | 0, 2 | $\geqslant 0$ |
| 11 | 1011 | $11=8+2+1$ | 0,2,3 | $\geqslant 0$ or overflow |
| 12 | 1100 | $12=8+4$ | 0, 1 | $\leqslant 0$ |
| 13 | 1101 | $13=8+4+1$ | 0, 1, 3 | $\leqslant 0$ or overflow |
| 14 | 1110 | $14=8+4+2$ | 0, 1, 2 | Any value |
| 15 | 1111 | $15=8+4+2+1 * *$ | 0,1,2,3 | Any value or overflow |

*No condition code is tested and no branch takes place. The next sequential instruction is executed.
** Unconditional branch

Table 8-3 lists the explicit format of the BC instruction with different mask values and their relation to the condition tested.

Table 8-3. Branch-on-Condition Instruction by Usage

| Hexadecimal Operation Code m1 | Mnemonic Code | Explicit <br> Format | Function |
| :---: | :---: | :---: | :---: |
| Used to Branch Around Nonexecutable Assembler Instructions and Directions |  |  |  |
| $\begin{aligned} & 07 \mathrm{~F} \\ & 070 \\ & 47 \mathrm{~F} \\ & 470 \end{aligned}$ | $\begin{aligned} & \mathrm{BCR} \\ & \mathrm{BCR} \\ & \mathrm{BC} \\ & \mathrm{BC} \end{aligned}$ | $\begin{aligned} & 15, \mathrm{r}_{2} \\ & 0, \mathrm{r}_{2} \\ & 15, \mathrm{~d}_{2}\left(x_{2}, \mathrm{~b}_{2}\right) \\ & 0, \mathrm{~d}_{2}\left(x_{2}, \mathrm{~b}_{2}\right) \end{aligned}$ | Branch unconditionally No operation <br> Branch unconditionally No operation |
| Used After Comparison Instructions |  |  |  |
| 472 <br> 474 <br> 478 <br> 47 D <br> 47 B <br> 477 | BC <br> BC <br> BC <br> BC <br> BC <br> BC | $\begin{aligned} & 2, \mathrm{~d}_{2}\left(x_{2}, b_{2}\right) \\ & 4, \mathrm{~d}_{2}\left(x_{2}, b_{2}\right) \\ & 8, \mathrm{~d}_{2}\left(x_{2}, b_{2}\right) \\ & 13, \mathrm{~d}_{2}\left(x_{2}, b_{2}\right) \\ & 11, \mathrm{~d}_{2}\left(x_{2}, b_{2}\right) \\ & 7, \mathrm{~d}_{2}\left(x_{2}, b_{2}\right) \end{aligned}$ | Branch if high <br> Branch if low <br> Branch if equal <br> Branch if not high <br> Branch if not low <br> Branch if not equal |
| Used After Test-Under-Mask Instructions |  |  |  |
| 471 <br> 478 <br> 474 <br> 47 E <br> 477 <br> 47 B | BC <br> BC <br> BC <br> BC <br> BC <br> BC | $\begin{aligned} & 1, d_{2}\left(x_{2}, b_{2}\right) \\ & 8, d_{2}\left(x_{2}, b_{2}\right) \\ & 4, d_{2}\left(x_{2}, b_{2}\right) \\ & 14, d_{2}\left(x_{2}, b_{2}\right) \\ & 7, d_{2}\left(x_{2}, b_{2}\right) \\ & 11, d_{2}\left(x_{2}, b_{2}\right) \end{aligned}$ | Branch if all ones <br> Branch if all zeros <br> Branch if mixed <br> Branch if not all ones <br> Branch if not all zeros <br> Branch if not mixed |
| Used After Arithmetic Instructions |  |  |  |
| 471 <br> 478 <br> 474 <br> 472 <br> 47 E <br> 477 <br> 47 B <br> 47 D | BC <br> BC <br> BC <br> BC <br> BC <br> BC <br> BC <br> BC | $\begin{aligned} & 1, d_{2}\left(x_{2}, b_{2}\right) \\ & 8, d_{2}\left(x_{2}, b_{2}\right) \\ & 4, d_{2}\left(x_{2}, b_{2}\right) \\ & 2, d_{2}\left(x_{2}, b_{2}\right) \\ & 14, d_{2}\left(x_{2}, b_{2}\right) \\ & 7, d_{2}\left(x_{2}, b_{2}\right) \\ & 11, d_{2}\left(x_{2}, b_{2}\right) \\ & 13, d_{2}\left(x_{2}, b_{2}\right) \end{aligned}$ | Branch if overflow <br> Branch if zero <br> Branch if minus <br> Branch if positive <br> Branch if not overflow <br> Branch if not zero <br> Branch if not minus <br> Branch if not positive |

## Operational Consideration:

- You can specify any of the general registers (2 through 12) as operand 2 of the BCR instruction.

Example (BC):

|  | $\begin{aligned} & \text { LABEL } \\ & 1 \end{aligned}$ | $\triangle O P E R A T I O N \triangle$ |  | OPERAND |
| :---: | :---: | :---: | :---: | :---: |
|  |  | 10 | 16 |  |
| 1. |  | CP | A, B |  |
| 2. |  | BC | 2, HIGH |  |
| 3. |  | BC | 4,LOW |  |
| 4. |  | BC | 8,EQUAL |  |
| 5. | EQUAL | AP | A, C |  |
|  | A | DC | P'650' |  |
|  | B | DC | P'650' |  |
|  | C | DC | P'1' |  |
|  |  | - |  |  |
|  |  | . |  |  |

In this example, two packed decimal values are compared. After the result is obtained, the condition code is stored in the PSW. The branch instructions are executed sequentially, and when the proper condition for the branch-on condition exists, a branch to the operand 2 address takes place.

1. Operands 1 and 2 compare equally since both $A$ and $B$ contained the packed decimal 650. The condition code is set to 0 .
2. The operand 1 mask 2 tests for condition code 2 . Since the condition code is not 2 (operand $1>$ operand 2 ), the next sequential instruction is processed.
3. The operand 1 mask 4 tests for condition code 1 . Since the condition code is not 1 (operand $1<$ operand 2 ), the next sequential instruction is processed.
4. The operand 1 mask 8 tests for condition code 0 . Since the condition code is 0 (operand $1=$ operand 2 ), a branch to the address of operand 2 (EQUAL) takes place.
5. Since the add decimal instruction has the label EQUAL, that is the instruction executed after the branch-on condition regardless of the sequential instructions in between.

## BCT

 BCTR
### 8.6. BRANCH ON COUNT (BCT, BCTR)



The branch on count (BCT and BCTR) instructions branch to the same instruction or routine a number of times (loop). Normally, before you execute a branch on count instruction, you load one of the general purpose registers with a value (the count) that refers to the number of times you want to loop to an instruction or routine. You specify the register containing the counter as operand 1 in your branch on count instruction. Each time the branch on count instruction is executed, the operand 1 register is decremented by one. Then the register is checked for a value of zero. If zero is not found, a branch to the instruction at the operand 2 address takes place. If the counter is 0 , no additional branching takes place, and the next sequential instruction is executed. You can use the BCTR instruction to decrement the counter register (operand 1) without branching, by specifying the operand 2 register as 0 . When BCTR is executed, the value in the operand 1 register is decremented by 1 , but since no branch address is supplied, the next sequential instruction is executed.

## Explicit Format:

| LABEL | $\triangle$ OPERATION $\triangle$ |  |
| :--- | :--- | :--- |
| OPERAND |  |  |
| [symbol] | BCT | $\mathrm{r}_{1}, \mathrm{~d}_{2}\left(\mathrm{x}_{2}, \mathrm{~b}_{2}\right)$ |
| [symbol] | BCTR | $\mathrm{r}_{1}, \mathrm{r}_{2}$ |

Implicit Format:

| LABEL | $\triangle$ OPERATION $\triangle$ |  |
| :--- | :--- | :--- |
| [symbol] | BCT | $r_{1}, s_{2}\left(x_{2}\right)$ |
| [symbol] | BCTR | $r_{1}, r_{2}$ |

Example:


This coding example adds AMOUNT (150) to SUM 10 times and stores the result in SUM (3-byte field).

1. The subtract ( SR ) instruction subtracts the operand 2 register value from the operand 1 register value and puts the result in operand 1 . In this case, register 6 is subtracted from itself, thus making it 0 . It is a good idea to clear a register before using it.
2. The load address (LA) instruction loads a count of 10 into register 6.
3. The add decimal (AP) instruction adds the packed decimal value in AMOUNT (150) to whatever is stored in SUM and stores the answer in SUM. SUM is defined as a packed decimal constant containing 0 . After the AP instruction is executed once, SUM contains 150.
4. The BCT instruction subtracts 1 from register 6 . Since register 6 now contains 9 , the AP instruction labeled BRANCHTO is executed again. After the AP is executed twice, SUM contains 300. The BCT instruction executes nine more times until the counter (register 6) is 0 . On the tenth attempt, no branch takes place, and NEXTSEQ is executed.

## Operational Considerations:

- The maximum value you can specify in the operand 1 counter register is $2^{32}$.
- You can specify any of the general registers ( 0 through 15 ) as operand 1.
- You can specify the operand 2 register of the BCTR instruction as 0 if you want to decrement the operand 1 counter register by 1 without causing a branch. When you specify 0 in operand 2, the next sequential instruction of your program is executed following the BCTR.
- The branch-to address in operand 2 is determined before the operand 1 register is decremented.


## EX

### 8.7. EXECUTE (EX)



The execute ( EX ) instruction is used to branch to an instruction elsewhere in your program, execute it with or without having modified it temporarily, and then branch back to the instruction following the EX instruction.

Explicit Format:


Implicit Format:


The address specified by operand 2 is the address of the instruction to which you branch following the EX instruction. This instruction, specified by operand 2 , is called the subject instruction. The operand 1 register determines whether or not change will be made to the subject instruction before execution. If register 0 is specified as the operand 1 register, no change is made to the subject instruction and it is executed following the EX instruction as if it were the next sequential instruction.

On the other hand, if any register other than zero is specified, bits 8 through 15 of the subject instruction are changed. This change is accomplished by the logical addition OR on the contents of bits 24 through 31 of the operand 1 register that you previously loaded and the contents of bits 8 through 15 of the subject instruction. (See logical OR instruction.) The result is placed in bits 8 through 15 of the subject instruction. The contents of the operand 1 register remain unchanged. Moreover, the change to the subject instruction is temporary and effective only during this execution of the subject instruction.

The instruction address and instruction length of the current PSW is changed by the execution of the EX and subject instruction. Normally, instruction sequencing continues with the instruction following the EX instruction. However, if the subject instruction is a successful branch instruction, the instruction address of the current PSW is replaced by the branch address and instruction sequencing resumes with the instruction address specified by the branch. If the subject instruction is a BAL or BALR, instruction sequencing resumes with the instruction address specified by the link register.

EX Instruction:


Subject instruction is RR type:


Subject instruction is RX type:


Subject instruction is RS type:


Subject instruction is SI type:


Subject instruction is SS Type 1:


Subject instruction is SS Type 2:


Operational Considerations:

- It isn't a good idea to alter instructions, but if it's absolutely necessary, you can use the EX instruction for that purpose.
- You can specify any of the general registers ( 0 through 15 ) as operand 1.
- Before the EX instruction causes a branch to the address you specify in operand 2, the current program address is stored in the PSW. Unless the branch to instruction (operand 2) is a successful branch instruction, sequential instruction execution follows execution of the subject instruction.
- If a program interrupt occurs after completion of the subject instruction, the old PSW contains either the address of the instruction following the EXECUTE or, in the case of a successful branch, the branch address. The current PSW contains the address of the instruction causing the interrupt (i.e., the operand 2 address in the EX instruction, or the branch-to address if a successful branch occurred before the interrupt).
- If the subject instruction is another EX instruction, a program exception occurs.
- A program exception can be caused by either the EX instruction itself or by the subject instruction.
- The condition code can be set by the subject instruction.

Example:

| LABEL 1 | $\triangle$ OPERATIONA |  | OPERAND |
| :---: | :---: | :---: | :---: |
|  | 10 | 16 |  |
|  | L | 4, =F'3' |  |
|  | EX | 4, MOVE |  |
|  | PUT | PRINT |  |
|  | - |  |  |
|  | $\cdot$ |  |  |
| move | MVC | $\emptyset(\emptyset, 5)$, INPUT |  |
|  | - |  |  |
|  | . |  |  |
|  | DS | ØH |  |
| InPUT | DS | CL8ø |  |
|  | - |  |  |
|  | - |  |  |
| PRINT | DTFPR | IOAREA $=$ OUTPU | 132, SAVAREA $=$ SAVE |

MOVE before execution of EX instruction and after execution of MVC instruction:

Register 4 before and after execution of EX instruction:
 instruction:

In the preceding coding example, register 4 is loaded with a value of 3. The EX instruction is executed. Register 4 indicates that change will be made to the subject instruction (MOVE). A branch is made to the subject instruction and a logical addition OR is performed on the contents of bits 24 through 31 of register 4 and the contents of bits 8 through 15 of the MVC instruction. The result is placed in bits 8 through 15 of the MVC instruction only for the duration of this execution of the MVC instruction. After execution of the MVC instruction is completed, a branch is made back to the instruction following the EX (PUT), and processing continues.

## 9. Decimal and Logical Instructions

### 9.1. USING DECIMAL INSTRUCTIONS

Decimal instructions perform arithmetic calculations on data located in main storage, using storage-to-storage instruction format. You must put decimal numbers into main storage before attempting to use them in mathematical calculations. Storage-to-storage instructions do not allow the use of general registers for calculations, since registers handle binary, not decimal, numbers. Decimal instructions are slower than instructions that use general registers (binary arithmetic, floating-point, etc.), because two main storage locations (specified in the operand fields) are accessed each time a decimal instruction is executed.

In assembly language, decimals are expressed in either unpacked or packed format. Format refers to the way bits represent decimal numbers. Unpacked format is the standard form in which numbers are brought in to the system (input), and sent out from the system (output). Packed format is the standard form in which numbers are used in mathematical calculations.

Numbers written in unpacked format are movable from one location in main storage to another and are printable on input and output devices. Arithmetic operations, however, can only make use of packed decimal numbers. Therefore, you must pack each number before you use it. In turn, you must then unpack the number before you output it (either to a printer or any other character sensitive device).

Unpacked format uses eight bits to represent a decimal number. The leftmost four bits are the zone field, and the rightmost four bits are the decimal digit in binary.


The zone portion of a number is always a binary 1111 which is a hexadecimal $F$. The $F$ in the zone field indicates that any decimal digit ( $0-9$ ) in the digit field is a numeric character in EBCDIC (Extended Binary Coded Decimal Interchange Code). These relationships are shown in the following chart.

| Decimal <br> Digit | Hexadecimal <br> (EBCDIC) Code | Binary <br> Code |
| :---: | :---: | :---: |
| 0 | FO | 111110000 |
| 1 | F1 | 11110001 |
| 2 | F2 | 11110010 |
| 3 | F3 | 11110011 |
| 4 | F4 | 11110100 |
| 5 | F5 | 11110101 |
| 6 | F6 | 11110110 |
| 7 | F7 | 11110111 |
| 8 | F8 | 11111000 |
| 9 | F9 | 11111001 |

Since decimal operations require the number you use to be in packed format, the decimal numbers must be defined as packed constants or converted from unpacked to packed format. To convert from unpacked to packed format, use the pack decimal (PACK) instruction. The PACK instruction removes the zone bits of the unpacked decimal, thus expressing the same value in fewer bytes of main storage.

In both unpacked and packed formats, the sign is expressed in the rightmost byte which is the zone portion in unpacked format and the rightmost digit portion in packed format.

The hexadecimal numbers $A$ through $F$ can be sign values that are either positive or negative, and are used in either ASCII or EBCDIC mode. A hexadecimal A and B are used for output of data in ASCII mode only. A represents a positive value and $B$ represents a negative value.

A hexadecimal C, D, and $F$ are all used for internal processing in EBCDIC mode. $C$ represents a positive value, $D$ represents a negative value, and $F$ represents an unsigned number which is assumed positive. If you attempt to print an unpacked decimal number with hexadecimal $C$ or $D$ as the sign value, an alpha character is printed for the rightmost byte instead of a decimal digit. Hexadecimal $C$ and $D$ must be changed to hexadecimal $F$ either through the ED or Ol instruction to print the correct value.

A hexadecimal $F$ is used for output of data in EBCDIC mode and represents an unsigned number which is assumed positive.

The following illustrations represent a 3-digit decimal number in both packed and unpacked format. Notice the positions of the zone and digit portions:

Unpacked Format:


Packed Format:


These illustrations represent the decimal number +456 in both packed and unpacked format.


There is a zone portion for every digit and one sign value in unpacked format and only digits and one sign value in packed format. Notice the number of bytes the unpacked format occupies in contrast to the packed format. The decimal number +456 occupies three bytes when unpacked and only two bytes when packed. The sign value hexadecimal $C$ indicates that 456 is a positive number.

### 9.2. DEFINING PACKED AND UNPACKED CONSTANTS AND MAIN STORAGE AREAS

You can specify packed or unpacked constants and reserve areas in main storage destined to hold packed decimal values by using the define constant (DC) and define storage (DS) statements. Their format is:


In this format, symbol is an optional predefined label that names the location of the constant or main storage area. The symbol's main storage address is the address of the leftmost byte of the constant or main storage area specified in the operand field. Relative addressing (symbol +4 ) is acceptable.

The duplication factor $d$ is a decimal number that tells the assembler how many times you want the constant reproduced or how many areas of the same length you want reserved in main storage. Specifying the duplication factor saves you the time of defining the same constant or area more than once.

The definition type is $P$ for packed or $Z$ for zoned (unpacked), which indicates the type of constant or main storage area you are specifying. There are other definition types available, but are used for other applications (Table 5-1).

The length factor Ln specifies the number of bytes of storage reserved for a constant (DC) or an area to be used in your program (DS). If no length is specified, the assembler assigns the length of the constant specified within apostrophes. By explicitly specifying a length, you can determine the lengths of all the fields in your program regardless of how large or small your constants are.

The constant itself (c) is enclosed in apostrophes. In the case of a DS statement, the constant you enclose in the apostrophes is not actually generated, but its length determines the length of the main storage area allocated. Embedded blanks cannot be used in packed and zoned type constants.

### 9.2.1. Packed Decimal Constants and Main Storage Areas

When you specify packed decimal constants, the character $P$ is the definition type in the operand field. Packed decimal constants can be up to 31 decimal digits ( 16 bytes) and can be signed or unsigned. If unsigned, the value is assumed to be positive. The address of the symbol you put in the label field is the address of the constant you define in the operand : field. When you specify a packed decimal constant, the actual decimal value you specify is placed into main storage.

Example:


1. This coding statement produces this packed decimal constant in main storage. The 3-byte length is implied since three bytes are needed to hold the constant and its sign.

| 0 | 4 | 5 | 6 | 3 | $C$ |
| :--- | :--- | :--- | :--- | :--- | :--- |

2. This coding statement produces this packed constant in main storage. In this case, the 3-byte length isn't needed to hold the constant, but since a length of three is specified, three bytes are allocated. The number is right-justified and thus the most significant unused bytes are zero-filled.

| 0 | 0 | 1 | 2 | 3 | $C$ |
| :--- | :--- | :--- | :--- | :--- | :--- |

3. This coding statement produces two consecutive, duplicate 2-byte constants in main storage.

| 1 | 2 | 3 | c | 1 | 2 | 3 | c |
| :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- |

The character P also is the definition type for defining packed decimal storage areas (i.e., areas destined to hold packed decimal data). The address of the symbol you put in the label field is the address of the constant you define in the operand field. No actual constant is placed into the area you reserve, and the area is not cleared of any data it may already contain. You are merely reserving a main storage area for future use.

Example:

| LABEL | $\triangle O P E R A T I O N A$ |  |
| :--- | :--- | :--- |
| 1 | 10 | 16 |


| 1. | NUM4 DS $P 1+45631$ <br> 2.   <br> NUM5 DS PL2 <br> NUM6 DS PLI'6' |
| :--- | :--- | :--- |

1. This coding statement reserves a 3-byte area in main storage. The statement does not put the packed decimal +4563 into that area but merely reserves an area large enough to hold it.
2. This coding statement reserves a 2-byte area in main storage. It does not clear the area or put anything into it.
3. This coding statement reserves a 1-byte area in main storage.

If you intend to reserve a packed storage area for mathematical calculations in either of these three ways, move zeros into the specified storage area to clear it of any leftover data from another program. This will ensure that mathematical calculations are performed correctly.

### 9.2.2. Unpacked Decimal Constants and Main Storage Areas

When you specify unpacked decimal constants, the character $Z$ is the definition type in the operand field. Unpacked decimal constants can be up to 16 decimal digits ( 16 bytes) and can be signed or unsigned. If unsigned, the value is assumed to be positive. The address of the symbol you put in the label field is the address of the constant you define in the operand field. When you specify an unpacked decimal constant, the actual decimal value you specify is placed into main storage as digits with zone fields of hexadecimal $F$.

Example:
$\begin{array}{llll}\text { LABEL } & \triangle O P E R A T I O N \triangle & \text { OPERAND } \\ 1 & 10 & 16 & \end{array}$

| 1. | [symbol] $D C$ | $Z^{\prime}+4563^{\prime}$ |
| :--- | :--- | :--- |
| 2. | [symbol] $D C$ | ZL5 ${ }^{\prime} 123^{\prime}$ |
| 3. | [symbol] $D C$ | $2 Z L 3^{\prime} 123^{\prime}$ |

1. This coding statement produces this unpacked decimal constant in main storage. The 4-byte length is implied since four bytes are needed to hold the unpacked constant with zones and sign.

| $F$ | 4 | $F$ | 5 | $F$ | 6 | $C$ | 3 |
| :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- |

2. This coding statement produces this unpacked decimal constant in main storage. In this case, the 5 -byte length isn't needed to hold the constant, but since a length of five is specified, five bytes are allocated. Note that the $C$ in the rightmost byte represents a signed positive value.

| 0 | 0 | 0 | 0 | $F$ | 1 | $F$ | 2 | $C$ | 3 |
| :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- |

3. This coding statement produces two consecutive 3-byte constants in main storage.

| $F$ | 1 | $F$ | 2 | $C$ | 3 | $F$ | 1 | $F$ | 2 | $C$ | 3 |
| :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- |

The character $Z$ also is the definition type for defining unpacked decimal main storage areas (i.e., area destined to hold unpacked decimal data). The address of the symbol you put in the label field is the address of the main storage area you define in the operand field. No actual constant is placed into the area you reserve, and the area is not cleared of any data it may already contain. You are merely reserving a main storage area.

## Example:

| LABEL | $\triangle O P E R A T I O N \triangle$ | OPERAND |
| :--- | :--- | :--- | :--- |
| 1 | 10 | 16 |


| 1. | ZNUM1 | DS |
| :--- | :--- | :--- |
| 2. | ZNUM2 | DS |
| 3. |  | ZL4 $43^{\prime}$ |
| ZNUM3 | DS | $2 Z L 4$ |

1. This coding statement reserves a 4-byte area in main storage. The actual unpacked decimal constant 4543 is not placed into the reserved area by this statement.
2. This coding statement also reserves a 4-byte area in main storage.
3. This coding statement reserves two consecutive 4-byte areas in main storage.

## AP

### 9.3. ADD DECIMAL (AP)



The add decimal (AP) instruction algebraically adds the packed decimal contents of operand 2 (the sending field) to the packed decimal contents of operand 1 (the receiving field). The sum is stored in operand 1 and is filled, a byte at a time, from right to left.

## Explicit Format:

| LABEL | $\triangle$ OPERATION $\triangle$ | OPERAND |
| :--- | :--- | :--- |
| [symbol] | AP | $d_{1}\left(I_{1}, b_{1}\right), d_{2}\left(I_{2}, b_{2}\right)$ |

Implicit Format:

| LABEL | $\triangle$ OPERATION $\triangle$ |  |
| ---: | :--- | :--- |
| OPymbol] | AP | $\mathrm{s}_{1}\left(I_{1}\right), s_{2}\left(I_{2}\right)$ |

Operational Considerations:

- The value and sign of the sum are algebraically, not logically, calculated.
- Since the sum is stored in the operand 1 location and if the length of the sum is greater than the length of operand 1, the leftmost digits of the sum are truncated.

Example:

| LABEL | $\triangle O P E R A T I O N A$ |  | OPERAND |
| :---: | :---: | :---: | :---: |
| 1 | 10 | 16 |  |
|  | AP | A, B |  |
|  | - |  |  |
|  | . |  |  |
| A | DC | P'2' |  |
| B | DC | P'9' |  |

A before AP execution:

$B$ before and after AP execution:


A after AP execution:


As shown, the entire sum (11) does not fit into the one byte allocated in operand 1, so the leftmost digit of the sum is lost. If the operand field of the DC statement defining $A$ is changed to PL2'2', two bytes are allocated for the sum, and the correct 2-byte sum fits into the allocated area. If the sum does not fill the length specified in operand 1 , zeros fill the remaining leftmost bytes of operand 1. A zero sum is positive as long as the length of operand 1 is large enough to hold the entire sum (i.e., no leftmost digits are lost). If the sum is zero and the leftmost digits are lost, the sign is the sign of the sum before the digits were lost. It is possible to double a number (add it to itself) when the rightmost bytes of operands 1 and 2 have overlapping bytes in main storage.

Example:
LABEL $\triangle O P E R A T I O N \triangle$ OPERAND

1016

|  | AP | $A, A$ |
| :---: | :---: | :---: |
| A | - |  |
| DC | $P^{\prime} 1234^{\prime}$ |  |

$$
\text { byte } 1 \text { byte } 2 \text { byte } 3
$$

A before AP execution:


A after AP execution:


The entire contents of $A$ is extracted, doubled and the answer returned to the same field. This destroys the original contents of $\mathbf{A}$.

## CP

### 9.4. COMPARE DECIMAL (CP)



The compare decimal (CP) instruction is used to compare operand 1 to operand 2, byte-bybyte from right to left. The result determines the setting of the condition code. (See 8.1.)

Explicit Format:

| LABEL | $\triangle$ OPERATION $\triangle$ | OPERAND |
| :--- | :--- | :--- |
| [symbol] | CP | $d_{1}\left(l_{1}, b_{1}\right), d_{2}\left(I_{2}, b_{2}\right)$ |

Implicit Format:

| LABEL | $\triangle$ OPERATION $\triangle$ |  |
| :--- | :--- | :--- |
| [Symbol] | CP | $s_{1}\left(I_{1}\right), s_{2}\left(I_{2}\right)$ |

Based on the comparison result, the condition code of the program status word (PSW) is set to 1 if operand 1 is less than operand 2 , to 2 if operand 1 is greater than operand 2 , and to 0 if operands 1 and 2 are equal.

The condition code is part of the PSW, a double-word register that holds information pertinent to instruction execution. The instruction executed following the CP instruction depends on the condition code setting. The four condition code settings are as follows:

| Condition Code <br> (Decimal Value) | Bit Configuration <br> (Bits 34-35 of PSW) |
| :---: | :---: |
| 0 | $00=$ test value is binary $8(1000)$ |
| 1 | $01=$ test value is binary $4(0100)$ |
| 2 | $10=$ test value is binary $2(0010)$ |
| 3 | $11=$ test value is binary $1(0001)$ |

## Operational Considerations:

- The CP instruction compares the rightmost byte of the operands first, and then works to the left one byte at a time.
- If operand 1 is shorter than operand 2 , or operand 2 is shorter than operand 1 , zeros fill the leftmost bytes of the shorter operand, thus making the operands the same length during the comparison. Even though zeros are added, neither operand is permanently changed by the instruction.
- Any zero compares equal to another zero regardless of their signs.
- Positive signs compared to each other compare as equal; and the same holds true for negative signs.
- It is possible to compare a decimal, or part of a decimal to itself, or part of itself, by overlapping the location of the rightmost bytes of the operands in main storage.

Example:


In this example, the packed decimal contents of operand 1 are compared to the packed decimal contents of operand 2. Operands 1 and 2 have overlapping rightmost bytes. The processor temporarily adds a byte of zeros to operand 2 since operand 2 has fewer bytes than operand 1. After the CP instruction is executed, the condition code is set to 2 because operand 1 is greater than operand 2.

## DP

### 9.5. DIVIDE DECIMAL (DP)



The divide decimal (DP) instruction divides the packed decimal contents of operand 1 (dividend) by the packed decimal contents of operand 2 (divisor). The result (quotient and remainder) is stored in operand 1 (the receiving field) which is filled from right to left.

## Explicit Format:

| LABEL | $\triangle$ OPERATION $\triangle$ | OPERAND |
| :--- | :--- | :--- |
| [symbol] | DP | $\mathrm{d}_{1}\left(\mathrm{I}_{1}, \mathrm{~b}_{1}\right), \mathrm{d}_{2}\left(\mathrm{I}_{2}, \mathrm{~b}_{2}\right)$ |

Implicit Format:

| LABEL | $\triangle$ OPERATION $\triangle$ |  |
| :--- | :--- | :--- |
| [symbol] | DP | $s_{1}\left(I_{1}\right), s_{2}\left(I_{2}\right)$ |

Operational Considerations:

- Operand 1 contains both the quotient and the remainder after the DP instruction is executed. Since operand 1 is the receiving field for the result, it consists of two side-by-side fields. The remainder with sign occupies the rightmost field, and the quotient with sign occupies the leftmost field. The leftmost byte of the quotient is the address specified by operand 1, and the rightmost byte of the remainder is the rightmost byte specified by operand 1 .
- The quotient with sign and the remainder with sign are determined algebraically. The sign of the remainder takes its sign value from the sign of the dividend.
- The length of the dividend is restricted to 16 bytes and must have at least one leading zero in the leftmost portion. As a result, the most significant digit is always zero. The length of operand 1 should be sufficient to hold the quotient, the remainder, and their signs.
- The divisor length is restricted to eight bytes. The operand 2 field, which holds the divisor, is unchanged after the DP instruction is executed.
- The length of the quotient is restricted to 15 bytes. This length is equal to the number of bytes needed to hold the dividend with sign and the divisor with sign (operand $1+$ operand 2).
- The length of the remainder must be at least one byte. The length of the remainder is the length of the divisor and is therefore restricted to eight bytes.
- If the result is larger than the length specified for operand 1, or if you attempt to divide by zero, a decimal divide program exception occurs.
- If you want to reuse operand 1 for further mathematical calculations, you must move a packed field of zeros into the specified area to clear it of any leftover data.
- In fixed-point instructions, it is your responsibility to keep track of assumed decimal points. To add or delete decimal places, you can multiply or divide by powers of 10. You can also use the move with offset (MVO) instruction (see 9.9) to drop any number of leftmost digits you specify.

Example:

| LABEL | $\triangle O P E R A T I O N \triangle$ |  | OPERAND |
| :---: | :---: | :---: | :---: |
| 1 | 10 | 16 |  |
|  | DP | NUMI, NUM2 |  |
|  | - |  |  |
|  | $\cdot$ |  |  |
| NUM1 | DC | PL3'234' |  |
| NUM2. | DC | P'21 |  |

NUM1 before execution of DP instruction:


NUM2 before and after execution of DP instruction:

NUM1 after execution of DP instruction:


Packed decimal number

Packed decimal number

Two packed decimal numbers

In this example, the packed decimal content of NUM1 is divided by the packed decimal content of NUM2. The result (quotient and remainder) replaces NUM1. Note the dividend is a 3 -byte field containing leading zeros. Its length is calculated by adding the actual number of bytes required to hold the data in NUM1 (two bytes) and NUM2 (one byte) which gives a total of three bytes for the dividend. Since the divisor is one byte, the remainder also is one byte. Note, the remainder with sign occupies the rightmost byte of NUM1 and the quotient with sign occupies the remaining (leftmost) portion of NUM1.

Example:

| LABEL | $\triangle O P E R A T I O N A$ |  | OPERAND |
| :---: | :---: | :---: | :---: |
| 1 | 10 | 16 |  |
|  | DP | NUM3, NUM4 |  |
|  | - |  |  |
|  |  |  |  |
| NUM3 | DC | PL4'646 ${ }^{\prime}$ |  |
| NUM4 | DC | P'35' |  |



In this example, the packed decimal content of NUM3 is divided by the packed decimal content of NUM4. The result is placed in NUM3. The length of operand 1 is calculated by adding the actual number of bytes required to hold the data in NUM3 ( 2 bytes) and NUM4 (2 bytes) which gives a total of four bytes for the dividend. In this example there also is a remainder of 16 that occupies the same number of bytes as the divisor and is located in the rightmost portion of operand 1.

## ED

### 9.6. EDIT (ED)

| General |  |  |  |
| :---: | :---: | :---: | :---: |
| opcode |  | FORMATTYPE | OBJECTINST.LGTH.(BYTES) |
| MNEM. | HEX. |  |  |
| ED | DE | SS | 6 |
| Condition Codes |  |  |  |
| SET TO 0 |  |  |  |
| - SETto 1 |  |  |  |
| - set to 2 |  |  |  |
| $\square$ SET TO 3 |  |  |  |
| SEE OPER. CONSIDERATIONS |  |  |  |


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

The edit (ED) instruction unpacks and modifies packed operand 2 data so that the printed output received is printed the way you want it displayed. This modification is controlled by the operand 1 edit pattern.

## Explicit Format:

| LABEL | $\triangle$ OPERATION $\triangle$ | OPERAND |
| :--- | :--- | :--- |
| [symbol] | ED | $d_{1}\left(l_{1}, b_{1}\right), d_{2}\left(b_{2}\right)$ |

Implicit Format:

| LABEL | $\triangle$ OPERATION $\triangle$ |  | OPERAND |
| :--- | :--- | :--- | :--- |
| [symbol] | ED | $s_{1}(\mathrm{I}), \mathbf{s}_{\mathbf{2}}$ |  |

The contents of operand 2 must be a packed decimal number. Operand 1 contains the edit pattern which consists of EBCDIC character codes. It is the pattern of EBCDIC character codes you specify that determines how results are displayed. The edit pattern can rearrange, delete, select, or insert any needed data, symbols, or characters in the operand 2 data. The edited result (unpacked and modified operand 2 data) replaces the operand 1 edit pattern.

## Operational Considerations:

- The length of the operand 1 edit pattern is almost always longer than operand 2 because operand 1 is in unpacked format while operand 2 is in packed format.
- The edited result replaces operand 1, thus permanently destroying the edit pattern. If you intend to reuse the edit pattern, then it must be saved or moved prior to the execution of the ED instruction.
- The total number of significance starters and digit selectors in operand 1 must equal the total number of digits in operand 2.
- If there is no significance starter in operand 1, all zeros in operand 2, and the fill character is hexadecimal 40, the resultant field is blank.
- The condition code reflects only the last field edited or the field after the last field separator.
- The $S$ switch reflects the sign of the last byte in operand 2. A plus sign detected as the least significant digit turns the $S$ switch off. A minus sign has no effect on the $S$ switch, and a plus or minus sign detected as the most significant digit causes a data exception.
- The sign of operand 2 is converted to hexadecimal $F$ when edited, regardless of whether it is a hexadecimal C or $F$ (positive), or a hexadecimal D (negative).


### 9.6.1. The Edit Pattern

The operand 1 edit pattern may consist of five types of pattern characters:

- Fill character
- Digit selector
- Significance starter
- Message character
- Field separator

The fill character in all cases, is the leftmost byte of operand 1. It is any EBCDIC character code you choose. The EBCDIC character code specified is the first byte of the edited result, and replaces (or fills in) certain pattern characters corresponding to any nonsignificant operand 2 digits. (The significant digits are the digits 1 thru 9. Zero is the only nonsignificant digit but becomes significant when it follows a significant digit or the significance starter (hexadecimal 21). The edited result replaces the operand 1 edit pattern. Some of the more commonly used fill characters are hexadecimal 40 (blank), hexadecimal 5B (dollar sign), and hexadecimal 5C (asterisk).

The digit selector is the EBCDIC character code 20. For every digit in operand 2, there must be a corresponding hexadecimal 20 in the operand 1 edit pattern. Every significant digit in operand 2 replaces its corresponding digit selector in operand 1. If there is a nonsignificant digit in operand 2, the fill character replaces its corresponding digit selector.

Example:

| Label | $\triangle O P E R A T I O N S$ |  | OPERAND |
| :---: | :---: | :---: | :---: |
| 1 | 10 | 16 |  |
|  | ED | PATTERNI,ANSWERI |  |
|  | - |  |  |
|  | - |  |  |
| PATTERN1 | DC | X'402ø2ø2め1 |  |
| ANSWERI | DC | P'253' |  |

PATTERN1 before execution of ED instruction:

ANSWER1 before and after execution of ED instruction:

PATTERN1 after execution of ED instruction:

Printed edit result looks like this:


Note that in PATTERN1 there is a corresponding hexadecimal 20 for every digit in ANSWER1. The edit pattern (operand 1) is examined one byte at a time and operand 2 is examined one digit at a time. The fill character remains as the first byte of the edit result (operand 1), and the succeeding pattern characters (in this example, the digit selectors) are replaced by unpacked operand 2 digits.

Example:

| ED | PATTERN2,ANSWER2 |
| :---: | :--- |
| $\dot{c}$ |  |
| PATTERN2 DC |  |
| ANSWER2 |  |
| DC |  |

PATTERN2 before execution of ED instruction:

ANSWER2 before and after execution of ED instruction:

PATTERN2 after execution of ED instruction:

Printed edit result looks like this:


In this example, note that ANSWER2 is padded to the left with a zero. Zero is considered a nonsignificant digit because it precedes any significant digits. Therefore, the fill character hexadecimal 40 replaces the second byte of the edit result, because zero corresponds to the first digit selector. The other packed operand 2 digits are unpacked and replace the remaining digit selectors. This method of changing lead zeros to blanks is called zero suppression.

The significance starter is the EBCDIC character code 21 . You need to specify only one hexadecimal 21 for each field to be edited. Every hexadecimal 21 must correspond to a digit in operand 2. When a hexadecimal 21 is examined in an edit pattern, it is replaced with its corresponding digit in operand 2 and then turns on the significance start switch ( S switch). The significance start switch is an internal switch that when turned on forces all of the following pattern characters either to remain or be replaced in the edit result. In effect, the only conditions that force the $S$ switch on are a hexadecimal 21 or a significant digit. On the other hand, the $S$ switch is turned off after a digit in operand 2 is examined whose sign is positive and located in the rightmost four bit positions of a field. A negative sign does not affect the $S$ switch. Whether the sign is positive or negative, all results are printed as positive values.

Example:



The fill character remains as the first byte of the edit result, and also replaces the significance starter because its corresponding digit in ANSWER3 is a nonsignificant zero. Now, the S switch is turned on and the second zero in ANSWER3 becomes significant. It replaces its corresponding digit selector with a zero. The succeeding operand 2 digits are unpacked and replace the remaining digit selectors.

The message character can be any EBCDIC character code except hexadecimal 20, 21, or 22. If the message character follows a significant digit or the significance start switch (hexadecimal 21), the message character remains as part of the edited result (operand 1). On the other hand, if the message character preceeds a significant digit or a hexadecimal 21 , it is replaced by the fill character. Some of the most commonly used message characters are hexadecimal 6B (comma) and hexadecimal 4B (decimal point).

Example:


PATTERN4 before execution
of ED instruction:

ANSWER4 before and after execution of ED instruction:

PATTERN4 after execution of ED instruction:

Printed edit result looks like this:


In this example, hexadecimal 5B (dollar sign) is used as the fill character. It remains as the first byte of the edited result and also replaces the second byte because the second byte's digit selector corresponds to a nonsignificant zero. The digit 1 in ANSWER4 replaces the third byte and the message character hexadecimal 6B remains because it follows a significant digit. The digits 3, 2, and 6 in operand 2 replace their corresponding pattern characters, the message character hexadecimal 4B remains and the trailing zeros in ANSWER4 replace their corresponding pattern characters.

Note the position of the significance starter hexadecimal 21 . In this example, the S switch is turned on by the first significant digit. Therefore, when this hexadecimal 21 is examined, it is replaced with its corresponding digit in ANSWER4. Now, suppose the edit pattern remains the same and operand 2 is changed to look like this example:

Example:


PATTERN5 before execution of ED instruction:

ANSWER5 before and after execution of ED instruction:

PATTERN5 after execution of ED instruction:

Printed edit result looks like this:


The significance starter (hexadecimal 21) is placed in the sixth byte of PATTERN5 so that the $S$ switch is turned on to force the display of bytes 7 through 10. As a result, the least significant dollar integer, the decimal point, and the cents are always represented no matter how small or large the value of operand 2 is.

The field separator is the EBCDIC character code 22. It is used to separate two or more contiguous fields. These fields must be packed decimal numbers in operand 2 and located in consecutive order in main storage. The fill character you specify replaces all field separators. As soon as a hexadecimal 22 is examined, the $S$ switch is turned off and the field separator is replaced with the fill character.

Example:


PATTERN6 before execution
of ED instruction:


In this example, ANSWER6 contains three packed contiguous fields each separated by two field separators (hexadecimal 22). Since the fill character specified is hexadecimal 40, that character is used as the fill character for all fields, and also replaces each field separator in the edit pattern. Remember that the $S$ switch is turned off as soon as a hexadecimal 22 is examined. This causes any leading zeros in succeeding fields to be nonsignificant digits.

### 9.6.2. The Resulting Condition Code

All operand 2 digits examined are tested for condition code 0 . The sign of the last packed field edited, and whether or not all the digits in that field are zeros, are recorded in the condition code setting when execution of the ED instruction is completed.

The condition code is set to 0 when:

- all digits in the last field edited in operand 2 are zeros;
- the edit pattern has no digit selectors or significance starters causing operand 2 digits not to be examined;
- the last character in the edit pattern is a field separator; and
- the edit pattern has no digit selectors or significance starters after the last field separator.

The condition code is set to 1 when:

- the last field edited is not all zeros but the $S$ switch is on. This indicates the value of the last field edited is less than zero, because a negative sign does not affect the $S$ switch.

The condition code is set to 2 when:

- the last field edited is not all zeros but the $S$ switch is off. This indicates the value of the last field edited is greater than zero, because a positive sign turns the $S$ switch off.


### 9.6.3. Examples of General Usage

The following examples are more commonly used and can be applied in practical situations. The first example shows how a nonblank fill character is used.

Example:

| LABEL | SOPERATIONA | OPERAND |
| :---: | :---: | :---: |
| 1 | 10 |  |


|  | ED | PATTERN7,ANSWER7 |
| :---: | :---: | :---: |
|  | - |  |
|  | - |  |
| PATTERN7 | DC | X'5C2ø2ø2ø2ø2め' |
| ANSWER7 | DC | P'12345' |

PATTERN7 before
execution of ED
instruction:

ANSWER7 before and after execution of ED instruction:

PATTERN7 after execution of ED instruction:

Printed edit result looks like this:


All results, whether positive or negative, are printed as positive results. By using message characters in the edit pattern, you can indicate whether a field in operand 2 is positive or negative. These message characters should be the last pattern characters in the edit pattern for each corresponding field in operand 2. If the value of operand 2 is negative, message characters placed to the right of the rightmost digit selector remain as part of the edit result. Since a negative sign in the rightmost four bit positions does not affect the $S$ switch, the message characters become significant. However, if the value of operand 2 is positive, the message characters are replaced by the fill character.

Since a positive sign in the rightmost four bit positions turns the $S$ switch off, the message characters become nonsignificant. You can specify any character or any number of characters to indicate a negative number, but the most commonly used are hexadecimal C3D9 (CR), hexadecimal C3C2 (DB), and hexadecimal 60 (-). The following example illustrates editing a negative number using the minus sign.

Example:

| LABEL | $\triangle O P E R A T I O N A$ | OPERAND |
| :--- | :--- | :--- |
| 1 | 10 | 16 |


|  | ED | PATTERN9,ANSWER9 |
| :---: | :---: | :---: |
|  | - |  |
|  | - |  |
| PATTERN9 | DC | X'4ø2ø2ø2ø2ø2ø6ø' |
| ANSWER9 | DC | $P^{\prime}-1234^{\prime}$ |



The following example illustrates date-field editing. Here, message characters are inserted into a five- or seven-digit field. The most commonly used message characters for a date field are hexadecimal 61 (slash), hexadecimal 60 (hyphen), and hexadecimal 40 (blank).

Example:

|  | ED | PATTERNA, ANSWERA |
| :---: | :---: | :---: |
|  | . |  |
|  | $\cdot$ |  |
| PATTERNA | DC | X'40212ø612ø2ø612ø2ø' |
| ANSWERA | DC | P'122576' |

PATTERNA before execution of ED instruction:

ANSWERA before and after execution of ED instruction:

PATTERNA after execution of ED instruction:

Printed edit result looks like this:


### 9.6.4. Summary

Table 9-1 summarizes and combines the information in this section to provide a clear and concise picture of the ED instruction and its functions.

Table 9-1. Edit Instruction Operation

| Pattern (Operand 1) Character | EBCDIC <br> Code | Previous <br> Switch <br> Status | Decimal (Operand 2) Digit | Sign of Least Significant Byte (Operand 2) | Resulting (Operand 1) Character | Resulting Switch Status |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| Fill character | Any | Off | Not examined | * | Fill character | Off |
| Digit selector | 20 | Off <br> Off <br> Off <br> Off <br> On <br> On <br> On <br> On | $\begin{aligned} & 0 \\ & 1-9 \\ & 1-9 \\ & 1-9 \\ & 0 \\ & 1-9 \\ & 1-9 \\ & 1-9 \end{aligned}$ | Positive <br> Negative <br> * <br> * <br> Positive <br> Negative | Fill character <br> Digit <br> Digit <br> Digit <br> Digit <br> Digit <br> Digit <br> Digit | Off <br> On <br> Off <br> On <br> On <br> On <br> Off <br> On |
| Significance starter | 21 | Off <br> Off <br> On <br> On | $\begin{aligned} & 0 \\ & 1-9 \\ & 0 \\ & 1-9 \end{aligned}$ | * | Fill character <br> Digit <br> Digit <br> Digit | On <br> On <br> On <br> On |
| Message character | Any except $20,21,22$ | Off <br> Off <br> On <br> On <br> On | Not examined <br> Not examined <br> Not examined <br> Not examined <br> Not examined | Positive <br> Positive <br> Negative | Fill character <br> Fill character <br> Message character <br> Fill character <br> Message character | Off <br> Off <br> On <br> Off <br> On |
| Field separator | 22 | $\begin{aligned} & \text { Off } \\ & \text { On } \end{aligned}$ | Not examined Not examined |  | Fill character Fill character | Off <br> Off |

[^1]
## MVC

### 9.7. MOVE CHARACTER (MVC)

| General |  |  |  | Possible Program Exceptions |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| OPCODE |  | FORMAT TYPE | OBJECT <br> INST. <br> LGTH. <br> (BYTES) | ADDRESSINGDATA (INVALIDSIGN/DIGIT)DECIMAL DIVIDEDECIMAL OVERFLOWEXECUTEEXPONENT OVERFLOWEXPONENT UNDERFLOWFIXED-POINT DIVIDEFIXED-POINT OVERFLOWFLOATING-POINT DIVIDEOPERATION | PROTECTION SIGNIFICANCE SPECIFICATION: NOT A FLOATING-POINT REGISTER <br> OP 1 NOT ON HALF-WORD BOUNDARY <br> OP 2 NOT ON HALF-WORD BOUNDARY <br> OP 2 NOT ON FULL-WORD BOUNDARY <br> OP 2 NOT ON DOUBLE-WORD <br> BOUNDARY <br> OP 1 NOT EVEN NUMBERED REGISTER <br> OP 1 NOT ODD NUMBERED REGISTER <br> NONE |  |
| MNEM. | HEX. |  |  |  |  |  |
| MVC | D2 | SS | 6 |  |  |  |
| Condition Codes |  |  |  |  |  |  |
| IF RESULT $=0$, SET TO 0 if RESULT<0, SET TO 1 if RESULT $>0$ O, SET TO 2 IF OVERFLOW, SET TO 3 UNCHANGED |  |  |  |  |  |  |

The move character (MVC) instruction moves the contents of one area in main storage (operand 2) into another area in main storage (operand 1). The length of operand 1 determines the number of bytes moved.

## Explicit Format:

| LABEL | $\triangle$ OPERATION $\triangle$ |  |
| :--- | :--- | :--- |
| [symbol] | MVC | $\mathrm{d}_{1}\left(1, \mathrm{~b}_{1}\right), \mathrm{d}_{2}\left(\mathrm{~b}_{2}\right)$ |

Implicit Format:

| LABEL | $\triangle$ OPERATION $\triangle$ |  | OPERAND |
| :---: | :--- | :--- | :--- |
| [symbol] | MVC | $\mathrm{s}_{1}\left(\mathrm{l}, \mathrm{s}_{\mathbf{2}}\right.$ |  |

The move character instruction moves data referenced by operand 2 (the sending field) to the location referenced by operand 1 (the receiving field). Data is moved a byte at a time from left to right. The length of operand 1 whether implied or explicit determines the number of bytes to be moved.

Operational Considerations:

- The instruction moves one byte at a time, processing from left to right through each field.
- The length of operand 1 determines the number of bytes moved. It can be either implied or explicit.
- When using operands with overlapping bytes, the results are often unpredictable.
- One character can be propagated through an entire field if the sending field begins with the first byte of a field and the receiving field begins with the second byte of that same field.
- Any type of data can be specified in an MVC instruction.

Example:

| 10 | 10 | 16 |
| :--- | :--- | :--- |

MVC RECEIVEI,SENDI

|  | MVC | RECEIVEI, SENDI |
| :--- | :---: | :--- |
|  | $\cdot$ |  |
| RECEIVEI | DC |  |
| SENDI CLS'DIGIT' |  |  |
| DC | CLS'SALES' |  |

RECEIVE1 before
execution of MVC instruction:

| $D$ |  | I |  | G |  | I |  | T |  |
| :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- |
| C | 4 | C | 9 | C | 7 | C | 9 | E | 3 |

Alpha characters

Hexadecimal (EBCDIC mode)

SEND1 before and after execution of MVC instruction:

RECEIVE1 after execution of MVC instruction:


In this example, the content of operand 2 is moved into operand 1 . Since it is an even move (a 5 -byte field to a 5 -byte field), the content of SEND1 completely overlays the content of RECEIVE1. Note that no length is specified for operand 1 and, as a result, the implied length is applied.

## Example:

|  | MVC | RECEIVE2 (5) , SEND2 |
| :--- | :--- | :--- |
|  | $\cdot$ |  |
| RECEIVE2 | DC |  |
| SEND2 | DC | CL7'JANUARY' |
| CL5ARCH: |  |  |

RECEIVE2 before execution of MVC instruction:

| J | A |  | $N$ |  | U |  | A |  | R |  | $Y$ |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| D 1 | C | 1 | D | 5 | E | 4 | C | 1 | D | 9 | E | 8 |

Alpha characters
Hexadecimal (EBCDIC mode)

SEND2 before and after execution of MVC instruction:


In the preceding example, an explicit length of 5 is specified for operand 1 . The 5 determines that RECEIVE2 will accept only five bytes from SEND2. The five bytes from SEND2 are moved to RECEIVE2 filling operand 1 from left to right. As you can see, five bytes of SEND2 (MARCH) are moved to the first five bytes of RECEIVE2 (JANUA). Note that the last two bytes of RECEIVE2 still remain.

Example:

| LABEL | $\triangle O P E R A T I O N \triangle$ | OPERAND |  |
| :--- | :--- | :--- | :--- |
| 10 | 10 | 16 |  |


|  | MVC | TOTAL(2), ANSWER+1 |
| :--- | :--- | :--- |
|  | $\cdot$ |  |
|  | $\cdot$ |  |
| TOTAL | DC | PL4' $\boldsymbol{l}^{\prime}$ |
| ANSWER | DC | PL3'128' |
| HEADING | DC | CLI9'TOTAL SALES FOR MAY' |

TOTAL before execution of MVC instruction:

ANSWER before and after execution of MVC instruction:

TOTAL after execution of MVC instruction:


Packed decimal number

Packed decimal number

Two packed decimal numbers

Since the concerned number occupies the second and third bytes of ANSWER, relative addressing (ANSWER +1 ) is used to address the second byte, and avoid the first byte of zeros. Note the number of bytes moved is restricted to two by using an explicit length in operand 1. If an explicit length is not specified, four bytes would be moved to TOTAL since it is a 4-byte field. Bytes two and three of operand 2, plus the first two bytes of data contiguous to operand 2 (in this case the letters TO of HEADING), would be moved to TOTAL.

Example:

| LABEL | $\triangle O P E R A T I O N \triangle$ |  |
| :---: | :---: | :---: |
| 1 | 10 | 16 |
|  | MVC | FIELD+1(3) , FIELD |
|  | - |  |
|  |  |  |
| FIELD | DC | CL4'1234' |

FIELD before execution of MVC instruction:

FIELD after byte 1 is moved:

FIELD after byte 2 is moved:

FIELD after byte 3 is moved:


As indicated, F1 is propagated through the entire field. This can be done using any character. If a hexadecimal 40 is used, the resultant field is EBCDIC blanks. If a hexadecimal FO is used, the resultant field is EBCDIC zeros. To propagate one character through an entire field, the sending field (operand 2) must begin with the first byte of that field and the receiving field (operand 1) must begin with the second byte of that same field. The move is processed from left to right. When operands 1 and 2 overlap, the end result is obtained by processing the operands one byte at a time, and putting each result byte immediately after the byte just obtained.

## MVN

### 9.8. MOVE NUMERICS (MVN)

| General |  |  |  | Possible Program Exceptions |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| OPCODE |  | FORMAT TYPE | OBJECT <br> INST. <br> LGTH. <br> (BYTES) | ADDRESSINGDATA (INVALIDSIGN/DIGIT)DECIMAL DIVIDEDECIMAL OVERFLOWEXECUTEEXPONENT OVERFLOWEXPONENT UNDERFLOWFIXED-POINT DIVIDEFIXED-POINT OVERFLOWFLOATING-POINT DIVIDEOPERATION | PROTECTION SIGNIFICANCE SPECIFICATION: NOT A FLOATING-POINT REGISTER OP 1 NOT ON HALF WORD BOUNDARY <br> OP 2 NOT ON HALF WORD BOUNDARY <br> OP 2 NOT ON FULL-WORD BOUNDARY <br> OP 2 NOT ON DOUBLE-WORD <br> BOUNDARY <br> OP 1 NOT EVEN NUMBERED REGISTER <br> OP 1 NOT ODD NUMBERED REGISTER <br> NONE |  |
| MNEM. | HEX. |  |  |  |  |  |
| MVN | D1 | SS | 6 |  |  |  |
| Condition Codes |  |  |  |  |  |  |
| IF RESULT $=0$, SET TO 0 IF RESULT<0, SET TO 1 IF RESULT $>0$ O, SET TO 2 IF OVERFLOW, SET TO 3 UNCHANGED |  |  |  |  |  |  |

The move numerics (MVN) instruction moves the low order four bits (digit portion) of each byte in operand 2 into the corresponding low order four bits of each byte in operand 1. The high order four bits (zone portion) of each byte in operand 1 remain unchanged. This instruction operates from left to right.

## Explicit Format:

| Label | $\quad \triangle$ OPERATION $\triangle$ |  |
| :--- | :--- | :--- |
| OPERAND |  |  |
| [symbol] | MVN | $d_{1}\left(1, b_{1}\right), d_{2}\left(b_{2}\right)$ |

Implicit Format:

| LABEL | $\triangle$ OPERATION $\triangle$ |  |
| :---: | :--- | :--- |
| [symbol] | MVN | $s_{1}(1), s_{2}$ |

## Operational Considerations:

- Any type of data can be specified in both operands 1 and 2.
- The condition code remains unchanged.
- The high order bit positions of each byte in operand 1 remain unchanged.

Example:

| LABEL | IOPERATIONA | OPERAND |  |
| :--- | :--- | :--- | :--- |
| 1 | 10 | 16 |  |

MVN TOTALI $+2(3)$, SUBTOT 1

TOTALI DC ZL5'12123'
SUBTOTI DC ZL3'345'

TOTAL1 before
execution of MVN instruction:


Binary hexadecimal (EBCDIC mode)

SUBTOT1 before and after execution of MVN instruction:

TOTAL1 after execution of MVN instruction:


Binary
hexadecimal (EBCDIC mode)

Binary hexadecimal (EBCDIC mode)

In this example, the low order four bit positions of each byte in SUBTOT1 are moved into the low order four bit positions of bytes 3, 4, and 5 of TOTAL1. The high order bit positions of each byte in TOTAL1 remain unchanged.

Example:

| 1. |  | AP | RESULT, $=P^{\prime} 5 \chi^{\prime}$ |
| :---: | :---: | :---: | :---: |
| 2. |  | MVN | RESULT+2 (1) , RESULT+3 |
|  |  | MVC | BUFFER,SPACES |
| 3. |  | MVC | BUFFER (3), RESULT |
|  |  | $\bullet$ |  |
|  | RESULT | DC | PL4'1234567' |
|  | BUFFER | DS | CL5 |
|  | SPACES | DC | CL5 ${ }^{\prime}$ |

RESULT before execution of AP instruction:

| 1 | 2 | 3 | 4 | 5 | 6 | 7 | $c$ |
| :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- |

Packed decimal number

Operand 2 before and after execution of AP instruction:


Packed decimal literal

RESULT after execution of AP instruction:


Packed decimal number

RESULT before execution of MVN instruction:

RESULT after execution of MVN instruction:


Packed decimal number

In this example, the MVN instruction is used in rounding numbers. In the first line of code, the literal fifty $(50)$ is added to the contents of RESULT to round the number to the first two decimal places.

Then, the low order four bits of byte 4 in RESULT are moved to the low order four bits of byte 3 in RESULT. When the MVN instruction is completed, the sign is moved to the right of the first two decimal places that were just rounded. The last byte of RESULT is ignored when the MVC instruction is executed. The location named BUFFER contains the final result.


BUFFER after execution of MVC instruction:


Packed decimal number

### 9.9. MOVE WITH OFFSET (MVO)

| General |  |  |  |
| :---: | :---: | :---: | :---: |
| OPCODE |  | $\begin{aligned} & \text { FORMAT } \\ & \text { TYPE } \end{aligned}$ | OBJECT INST. LGTH. <br> (BYTES) |
| MNEM. | HEX. |  |  |
| MVO | F1 | SS | 6 |
| Condition Codes |  |  |  |
| IF RESULT $=0$, SET TO 0 if Result <o, SETto 1 Ifresult $>0$ o, set to 2 If overflow, set to 3 UNCHANGED |  |  |  |


| Possible Program Exceptions |  |
| :--- | :--- |
| $\square$ ADDRESSING | $\square$ PROTECTION |
| $\square$ DATA (INVALIDSIGN/DIGIT) | $\square$ SIGNIFICANCE |
| $\square$ DECIMAL DIVIDE | $\square$ SPECIFICATION: |
| $\square$ DECIMAL OVERFLOW | $\square$ NOT A FLOATING-POINT REGISTER |
| $\square$ EXECUTE | $\square$ OP 1 NOT ON HALF-WORD BOUNDARY |
| $\square$ EXPONENT OVERFLOW | $\square$ | OP 2 NOT ON HALF-WORD BOUNDARY

The move with offset (MVO) instruction moves the contents of operand 2 into operand 1 offsetting the data one half-byte to the left during the move.

Explicit Format:

| LABEL | $\triangle$ OPERATION $\triangle$ | OPERAND |
| :---: | :--- | :--- |
| [symbol] | MVO | $\mathrm{d}_{1}\left(\mathrm{I}_{1}, \mathrm{~b}_{1}\right), \mathrm{d}_{2}\left(\mathrm{I}_{2}, \mathrm{~b}_{2}\right)$ |

Implicit Format:

| LABEL | $\triangle$ OPERATION $\triangle$ |  |
| :--- | :--- | :--- |
| [symbol] | MVO | $s_{1}\left(I_{1}\right), s_{2}\left(I_{2}\right)$ |

The MVO instruction operates from right to left. Data from operand 2 (the sending field) is moved into operand 1 (the receiving field) but offset one half-byte to the left. The low order four bits of the rightmost byte in the receiving field remain unchanged. If operand 2 data does not completely fill operand 1, the leftmost unfilled bytes of operand 1 are padded with zeros. However, if the operand 2 field is larger than the operand 1 field, the leftmost bytes of operand 2 are truncated. The MVO instruction is most commonly used in rounding packed decimal numbers to an odd number of digits.

Operational Considerations:

- Usually, the MVO instruction operates on packed decimal fields; however, unpacked fields can be specified.
- Padding of zeros to the left and truncation to the left can occur.
- Condition code remains unchanged.

Example:


MVO FIELDI,FIELD2

|  | $\cdot$ |  |
| :--- | :---: | :--- |
|  | FIELDI |  |
| DC | XL4'FFFFFFFF' |  |
| FIELD2 | DC | XL3'AABBCC' |

FIELD1 before execution of MVO instruction:


Binary hexadecimal characters

Binary
hexadecimal characters

FIELD1 after execution of MVO instruction:

| 1010 | 1010 | 1011 | 1011 | 1100 | 1100 |
| :---: | :---: | :---: | :---: | :---: | :---: |
| A | A | B | B | C | C |


| 0000 | 1010 | 1010 | 1011 | 1011 | 1100 | 1100 | 1111 |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| 0 | A | A | B | B | C | C | F |

Binary hexadecimal characters

In this example, the content of FIELD2 is moved (starting from right to left) into FIELD1 offset by one half-byte to the left. The low order four bits of the rightmost byte of FIELD1 (1111, or hexadecimal F) remain unchanged.

Each half-byte of FIELD2 fills its corresponding half-byte of FIELD1. The high order four bits of the leftmost byte of FIELD1 are padded with binary zeros since the operand 1 field is larger than operand 2.

## Example:

| MVO | PRICE,PRICE (2) |  |
| :---: | :---: | :---: |
| PRICE | $\cdot$ |  |
| $\dot{D} C$ | $P^{\prime} 37254^{\prime}$ |  |

## operand 1

PRICE before execution of MVO instruction:

PRICE after execution of MVO instruction:


In this example, the MVO instruction is used in rounding packed decimal numbers. An explicit length is specified for operand 2 and both operands have overlapping bytes. If all decimal places are needed in the final result, then this rounding technique is not useful. The purpose of this MVO instruction is to move the final result (dollars and cents) next to the sign so that it can be edited and printed. Note the decimal number 4 in the high order four bits of the rightmost byte of operand 1 is replaced with the decimal number 5 and binary zeros are padded in the high order four bits of the leftmost byte of operand 1.

## MVZ

### 9.10. MOVE ZONES (MVZ)



The move zones (MVZ) instruction moves the high order four bits (zone portion) of each byte in operand 2 into the corresponding high order four bits of each byte in operand 1.

## Explicit Format:

| LABEL | $\triangle$ OPERATION $\triangle$ | $\cdot$ |
| :---: | :---: | :--- |
| [symbol] | MVZ | $\mathrm{d}_{1}\left(\mathrm{I}, \mathrm{b}_{1}\right), \mathrm{d}_{2}\left(\mathrm{~b}_{2}\right)$ |

Implicit Format:

| LABEL | $\triangle$ OPERATION $\triangle$ |  | OPERAND |
| :--- | :--- | :--- | :--- |
| [symbol] | MVZ | $\mathrm{s}_{1}(\mathrm{I}), \mathrm{s}_{2}$ |  |

This instruction operates from left to right. The low order four bits of each byte in operand 1 remain unchanged. If the operand 2 field is larger than operand 1 , the zone portions of the leftmost bytes of operand 2 are truncated. On the other hand, if the operand 1 field is larger than operand 2, the zone portions of the leftmost bytes in operand 1 remain unchanged.

Operational Considerations:

- The contents of both operands should contain zoned numeric fields; however, any type of data can be specified.
- The low order four bits of each byte in operand 1 remain unchanged.
- Operands 1 and 2 can have overlapping bytes.
- The condition code remains unchanged.

Example:

| LABEL |  |
| :--- | :--- |
| 1 | 10 |

OPERAND

|  | MVZ | NUMPOS, NUMNE |
| :---: | :---: | :---: |
|  | - |  |
|  | - |  |
| NUMPOS | DC | $713^{\prime} 456^{\prime}$ |
| NUMNEG | DC | XL3 ${ }^{\prime} \mathrm{F} \emptyset \mathrm{F} \emptyset 0 \emptyset{ }^{\prime}$ |

NUMPOS before execution of MVZ instruction:


Binary zoned decimal number (positive)

NUMNEG before and after execution of MVZ instruction:

NUMPOS after execution of MVZ instruction:


Binary zoned decimal number (negative)

Binary zoned decimal number (negative)

In this example, the zone portions of each byte in NUMNEG are moved into the corresponding zone portions of each byte in NUMPOS. As a result, the sign is changed from positive to negative by moving a hexadecimal $D$ into the high order four bits of the rightmost byte of NUMPOS. The other two zone portions are replaced with the same hexadecimal value.

## MP

### 9.11. MULTIPLY DECIMAL (MP)



The multiply decimal (MP) instruction algebraically multiplies the packed decimal contents of operand 2 (multiplicand) by the packed decimal contents of operand 1 (multiplier) and stores the result (product) in operand 1. The receiving field (operand 1) is filled from right to left.

## Explicit Format:



Implicit Format:


Because the result replaces operand 1, you must ensure that the operand 1 field is large enough to hold the product. This is determined by adding the number of bytes required to hold the multiplicand to the number of bytes required to hold the multiplier.

$$
\begin{aligned}
& \text { length of } \\
& \text { multiplicand }
\end{aligned} \quad+\begin{aligned}
& \text { length of } \\
& \text { multiplier }
\end{aligned} \quad \begin{aligned}
& \text { length of } \\
& \text { operand } 1 \text { (product) }
\end{aligned}
$$

If you use this rule, the multiplicand will have at least as many high order zeros as the number of digits in the multiplier. These high order zeros prevent overflow from occurring in the final result.

The multiplier (operand 2) can be up to 8 bytes long which can consist of 15 digits and a sign. The resultant product (operand 1) can be up to 16 bytes long which can consist of 31 digits and a sign.

Example:


HOURS before execution of MP instruction:

$\left.\begin{array}{|lll|l|l|l|l|l|l|}\hline 0 & 1 & 0 & 0 & 1 & 0 & 0 & 4 & 0\end{array}\right]$$\quad$|  |
| :--- | :--- |

RATE before and after execution of MP instruction:


HOURS after execution of MP instruction:


In this example, the length of operand 1 is determined by adding the number of bytes required to hold the packed decimal 40 ( 2 bytes) to the number of bytes required to hold the packed decimal 500 ( 2 bytes) which gives the total of 4 bytes. Then the multiplication operation takes place operating from right to left. The product replaces HOURS and the sign is determined algebraically. (In this example, positive $\times$ positive $=$ positive.)

## Operational Considerations:

- The operand 1 field must be large enough to hold the product.
- The operand 2 field is limited to 8 bytes in length and the operand 1 field is limited to 16 bytes in length.
- Since a symbolic name references the leftmost or high order portion of a location in main storage, overlapping bytes can exist in the rightmost bytes only.

If overlapping bytes exist in the leftmost portion, the number of bytes required to hold the multiplicand and the multiplier will be larger than the receiving field.

- The condition code remains unchanged.
- Multiplication by powers of 10 adds decimal places to a specified value.


## PACK

### 9.12. PACK DECIMAL (PACK)

| General |  |  |  | Possible Program Exceptions |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| OPCODE |  | FORMATTYPE | OBJECT <br> INST. <br> LGTH. <br> (BYTES) | ADDRESSINGDATA (INVALIDSIGN/DIGIT)DECIMAL DIVIDEDECIMAL OVERFLOWEXECUTEEXPONENT OVERFLOWEXPONENT UNDERFLOWFIXED-POINT DIVIDEFIXED-POINT OVERFLOWFLOATING-POINT DIVIDEOPERATION | PROTECTION SIGNIFICANCE SPECIFICATION: 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 OP 2 NOT ON DOUBLE-WORD BOUNDARY <br> OP 1 NOT EVEN NUMBERED REGISTER <br> OP 1 NOT ODD NUMBERED REGISTER NONE |  |
| MNEM. | HEX. |  |  |  |  |  |
| PACK | F2 | SS | 6 |  |  |  |
| Condition Codes |  |  |  |  |  |  |
| IF RESULT $=0$, SET TO O IF RESULT < O, SET TO 1 IF RESULT $>0$ O. SET TO 2 IF OVERFLOW, SET TO 3 UNCHANGED |  |  |  |  |  |  |

The pack decimal (PACK) instruction converts data in operand 2 from unpacked format to packed format. (See 9.1.) The result replaces operand 1.

## Explicit Format:

| LABEL | $\triangle$ OPERATION $\triangle$ | OPERAND |
| :---: | :---: | :---: |
| [symbol] | PACK | $d_{1}\left(l_{1}, b_{1}\right), d_{2}\left(l_{2}, b_{2}\right)$ |

Implicit Format:

| LABEL | $\triangle$ OPERATION $\triangle$ |  |
| :---: | :--- | :--- |
| [symbol] | PACK | $s_{1}\left(I_{1}\right), s_{2}\left(I_{2}\right)$ |

Any data that is to be used in decimal arithmetic must be stored in packed decimal format before any arithmetic operations are performed. After your calculations are processed, packed data must be changed back to unpacked (zoned decimal) format to be sent to the printer or any other character sensitive device. Remember, when data is input from an external device (i.e., card reader), the data is stored in zoned decimal format. Operand 2 , the sending field, is defined as a character type or zoned type field. Operand 1, the receiving field, is defined as a packed field and should contain enough bytes to receive all digits (plus the sign) from operand 2.

The formula for computing the number of bytes required to receive unpacked operand 2 data is:

$$
\frac{(\text { Number of bytes of operand } 2)+1}{2}=
$$

number of bytes required for packed operand 1 field (round upward to the nearest byte)

When the PACK instruction is executed, all zones in operand 2 are ignored except the zone in the rightmost byte. That zone portion (the sign) and the digit portion are reversed and placed in the rightmost byte of operand 1 . Each digit in operand 2 is placed in operand 1 next to the rightmost byte, filling in from right to left. Any unfilled bytes of half-bytes that are part of the specified length for operand 1 are zero-filled. Any unfilled bytes that are not part of the specified length for operand 1 remain unchanged.

## Operational Considerations:

- Operand 2 data should be in zoned decimal format.
- Operand 1 should contain enough bytes to receive all digits (plus the sign) from operand 2.
- This instruction operates from right to left.
- Any unfilled bytes or half-bytes that are part of the specified length for operand 1 are zero-filled.
- Any unfilled bytes that are not part of the specified length for operand 1 remain the same.
- Specification of a length attribute for operands 1 and 2 is optional.
- The condition code remains unchanged.

Example:
AMT DC ZL4'1234'
AMTP DC PL3'め'

AMTP before execution
of PACK instruction:

| 0 | 0 | 0 | 0 | 0 | $c$ |
| :--- | :--- | :--- | :--- | :--- | :--- |

Packed decimal number

AMT before and after execution of PACK instruction:

AMTP after execution of PACK instruction:


Zoned or unpacked decimal number

## zero

 filled| 0 | 1 | 2 | 3 | 4 | $c$ |
| :--- | :--- | :--- | :--- | :--- | :--- |

Packed decimal number

In this example, the content of AMT (a 4-byte zoned decimal number) is packed into AMTP (a 3-byte packed field of zeros). The sign and digit portions of the rightmost byte of AMT are reversed and placed in the rightmost byte of AMTP. Then the next digit (3) is placed next to the left of the rightmost byte. Then digit 2 is placed to the left of digit 3 and digit 1 is placed to the left of digit 2. The high order four bits of the leftmost byte are zero filled. As you can see in this example, two decimal digits occupy a single byte with the exception of the rightmost (sign) byte. Note that a length attribute is specified for both operands in the examples. The length attribute can be omitted but it is suggested it be included for clarity.

## Example:



AMOUNTIN before execution of PACK instruction:

AMOUNTIN during execution of PACK instruction:

AMOUNTIN after execution of PACK instruction:


This example shows that the content of AMOUNTIN (a 3-byte zoned decimal field) is packed into part of itself (AMOUNTIN+1, a 2-byte zoned decimal field). The zone portion (F) and digit portion (8) of the rightmost byte of AMOUNTIN are reversed and placed in the rightmost byte of AMOUNTIN+1. The digits 6 and 7 are placed to the left of the rightmost byte, 6 in the low order four bits and 7 in the high order four bits. Because the leftmost byte of AMOUNTIN is not part of the resultant field, that byte remains unchanged. Since AMOUNTIN is now a part zoned, part packed field, you should move the packed decimal number to another field before performing any mathematical calculations. Note that packing a number into itself is not considered good practice since results are often unpredictable.

Example:


INVAMT before execution of PACK instruction:

Zoned decimal number

INVAMT during execution of PACK instruction:


INVAMT after execution of PACK instruction:


Packed decimal number

The content of INVAMT (a 5-byte zoned field) is packed into itself. The zone portion (D) and the digit portion ( 0 ) of the rightmost byte are reversed and returned to the same byte. The remaining zones are ignored. The remaining digits are placed in INVAMT starting next to the rightmost byte and filling each half-byte from right to left. Because the full length of operand 1 is specified, the remaining unfilled bytes are zero-filled.

## SP

### 9.13. SUBTRACT DECIMAL (SP)

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

The subtract decimal (SP) instruction algebraically subtracts the packed decimal contents of operand 2 from the packed decimal contents of operand 1 and stores the result in operand 1.

Explicit Format:

| LABEL | $\triangle$ OPERATION $\triangle$ | OPERAND |
| :---: | :--- | :--- |
| [symbol] | $S P$ | $d_{1}\left(I_{1}, b_{1}\right), d_{2}\left(I_{2}, b_{2}\right)$ |

Implicit Format:

| LABEL | $\triangle$ OPERATION $\triangle$ |  |
| :---: | :--- | :--- |
| [symbol] | SP | $s_{1}\left(I_{1}\right) s_{2}\left(I_{2}\right)$ |

Operand 1 (minuend) and operand 2 (subtrahend) must be in packed decimal format. The operand 1 field should be equal and in most cases larger than the size of operand 2 . If operand 1 is too short to contain the result (difference), an overflow condition occurs. Subtraction is algebraic, concerning the signs and digits of both operands. If the sign of operand 2 is negative, it is treated as positive; if positive, it is treated as negative. Then, both operands are added together and the result is placed in operand 1. The sign of the difference is determined by the rules of algebra. If the result is ismaller than the operand 1 field, any unfilled leftmost bytes are zero filled. On the other hand, if the result is larger than the operand 1 field, the leftmost bytes of the result are truncated.

## Operational Considerations:

- Operands 1 and 2 must be in packed decimal format.
- The length of operand 1 should be equal to or larger than the length of operand 2.
- Subtraction is algebraic.

Example:


GROSS before execution of SP instruction:


Packed decimal number (assumed decimal point)

DEDUCT before and after execution of SP instruction:


Packed decimal number (assumed decimal point)

GROSS after execution of SP instruction:


Packed decimal number (assumed decimal point)

In this example, the content of DEDUCT is subtracted from the content of GROSS. The result replaces GROSS and, in this example, completely fills the operand 1 field. The signs of both operands are positive which produces a positive result.

Example:

|  | SP | FIELD, FIELD $+2(2)$ |
| :---: | :---: | :---: |
| FIELD | - |  |
| DC | P'6249311' |  |

operand 1
FIELD before execution of SP instruction:


Packed decimal number
operand 2
(assumed decimal point)
FIELD after execution of SP instruction:


Here is an example of setting the rightmost part of a field to zeros. The contents of FIELD +2 (a 2-byte field) are subtracted from the contents of FIELD (a 4-byte field). The result replaces the rightmost two bytes of FIELD. The signs of both operands are positive and by the rules of algebra produces a positive result. This instruction operates from right to left. The SP instruction starts with the rightmost bytes of both operands regardless of the differences in length. If you are concerned with whole numbers only, you may want to zero-fill any undesired decimal places. This SP instruction is used as a method to zero-fill any decimal places to the right of the decimal point.

## Example:



The SP instruction subtracts the contents of ITEMS (a 2-byte field) from the contents of QTY (a 2-byte field). The result replaces QTY and a zero fills the leftmost unused half-byte. The signs are different, however. Operand 2 is unsigned and assumed to be positive. Since the sign of operand 2 is positive, it is treated as negative. Now, both operands 1 and 2 are negative and are added together. The sign of the result is negative since the rules of algebra determine that the sign of the operand with the highest absolute value (in addition and subtraction) determines the sign of the result.

## UNPK

### 9.14. UNPACK DECIMAL (UNPK)

| General |  |  |  |
| :---: | :---: | :---: | :---: |
| OPCODE | FORMAT | OBJECT <br> INST. <br> TYPE |  |
| MNTH. <br> (BYTES) |  |  |  |
| UNEM. | HEX. |  |  |
| UNPK | F3 | SS | $\mathbf{6}$ |


| Condition Codes |
| :---: |
| $\square$ IF RESULT $=0$ O, SET TO O |
| $\square$ IF RESULT $<$ O, SET TO 1 |
| $\square$ IF RESULT $>0$ O, SET TO 2 |
| $\square$ IF OVERFLOW, SET TO 3 |
| $\square$ UNCHANGED |


| Possible Program Exceptions |  |
| :---: | :---: |
| - ADDRESSING | - PROTECTION |
| $\square$ DATA (INVALIDSIGN/DIGIT) | $\square$ SIGNIFICANCE |
| $\square$ DECIMAL DIVIDE | $\square$ SPECIFICATION: |
| $\square$ DECIMAL OVERFLOW | $\square$ NOT A FLOATING-POINT REGISTER |
| $\square$ EXECUTE | $\square$ OP 1 NOT ON HALF-WORD BOUNDARY |
| $\square$ EXPONENT OVERFLOW | $\square$ OP 2 NOT ON HALF-WORD BOUNDARY |
| $\square$ EXPONENT UNDERFLOW | $\square$ OP 2 NOT ON FULL-WORD BOUNDARY |
| $\square$ FIXED-POINT DIVIDE | $\square$ OP 2 NOT ON DOUBLEWORD |
| $\square$ FIXED-POINT OVERFLOW | BOUNDARY |
| FLOATING-POINT DIVIDE | OP 1 NOT EVEN NUMBERED REGISTER OP 1 NOT ODD NUMBERED REGISTER |
| $\square$ OPERATION | $\square$ NONE $\square$ |

The unpack decimal (UNPK) instruction converts data in operand 2 from packed format to unpacked (zoned decimal) format. (See 9.1.) The result replaces operand 1.

## Explicit Format:

| LABEL | $\triangle$ OPERATION $\triangle$ | OPERAND |
| :---: | :--- | :--- |
| [symbol] | UNPK | $\mathrm{d}_{1}\left(\mathrm{l}_{1}, \mathrm{~b}_{1}\right), \mathrm{d}_{2}\left(\mathrm{l}_{2}, \mathrm{~b}_{2}\right)$ |

Implicit Format:

| LABEL | $\triangle$ OPERATION $\Delta$ |  |
| :--- | :--- | :--- |
| [symbol] | UNPK | $s_{1}\left(I_{1}\right), s_{2}\left(I_{2}\right)$ |

Data that is to be printed or sent to any other character-sensitive device must be stored in zoned decimal format. Operand 2, the sending field, is defined as a packed field. Operand 1 , the receiving field, is defined as a character type or zoned type field. Operand 1 should contain enough bytes to receive all digits, a zone for each digit, and the sign from operand 2.

The formula for computing the number of bytes required to receive packed operand 2 data is:
(Number of bytes of operand 2) $\times 2-1=$ number of bytes required for unpacked operand 1 field.

The UNPK instruction reverses the zone and digit portion (the sign) of the rightmost byte of operand 2 and places it in the rightmost byte of operand 1 . Each half byte of operand 2 is moved to a digit portion and a hexadecimal $F$ (binary 1111) fills each zone portion in operand 1. The move takes place from right to left, consecutively. Any unfilled bytes that are part of the specified length for operand 1 are zero-filled. If the operand 1 field is too short, the leftmost bytes of operand 2 are truncated.

Operational Considerations:

- 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 the sign from operand 2.
- This instruction operates from right to left.
- Any unfilled bytes that are part of the specified length for operand 1 are zero-filled.
- Specification of a length attribute for operands 1 and 2 is optional.
- The condition code remains unchanged.

Example:


TOTALU before execution of UNPK instruction:


TOTALP before and after execution of UNPK instruction:

TOTALU after execution of UNPK instruction:


The UNPK instruction changes the packed format of TOTALP to unpacked format and places the result in TOTALU. The zone (5) and digit (C) portions of TOTALP are reversed and placed in the rightmost byte of TOTALU. The digit 2 fills the digit portion and a hexadecimal $F$ fills the zone portion next to the rightmost byte. Then the digit 1 fills the digit portion and a hexadecimal F fills the zone portion to the left of the byte just filled. As you can see, the field requiring 2 bytes to store the original packed data now requires 3 bytes to store the same data but in unpacked format. Note that a length attribute is specified for both operands, although it can be omitted.

Example:

| $\underset{1}{\text { LABEL }}$ | $\triangle O P E R A T I O N A$ |  | OPERAND |
| :---: | :---: | :---: | :---: |
|  | 10 | 16 |  |
|  | UNPK | TOTAMT, TOTAMT |  |
|  | - |  |  |
|  | - |  |  |
| totamt | DC | P'1234' |  |

TOTAMT before execution of UNPK instruction:


Packed decimal number

TOTAMT during execution of UNPK instruction:


TOTAMT after execution of UNPK instruction:


The UNPK instruction reverses the zone (4) and digit (C) portions and returns it to the same byte. The next half byte (3) replaces the digit portion and a hexadecimal $F$ fills in the zone portion next to the half byte just filled. No length attributes are specified, so the implied lengths are used. As you can see, the result received is not the result expected. So, remember that unpacking a number into itself is not considered good practice since some results are often unpredictable.

## ZAP

### 9.15. ZERO AND ADD DECIMAL (ZAP)

| General |  |  |  | Possible Program Exceptions |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| OPCODE |  | $\begin{aligned} & \text { FORMAT } \\ & \text { TYPE } \end{aligned}$ | OBJECT <br> INST. <br> LGTH. <br> (BYTES) | ADDRESSING <br> DATA (INVALID SIGN/DIGIT) DECIMAL DIVIDE DECIMAL OVERFLOW EXECUTE EXPONENT OVERFLOW EXPONENT UNDERFLOW FIXED-POINT DIVIDE FIXED-POINT OVERFLOW FLOATING-POINT DIVIDE OPERATION | PROTECTION SIGNIFICANCE SPECIFICATION: 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 OP 2 NOT ON DOUBLE-WORD BOUNDARY <br> OP 1 NOT EVEN NUMBERED REGISTER <br> OP 1 NOT ODD NUMBERED REGISTER <br> NONE |  |
| MNEM. | HEX. |  |  |  |  |  |
| ZAP | F8 | SS | 6 |  |  |  |
| Condition Codes |  |  |  |  |  |  |
|  |  |  |  |  |  |  |  |  |
| IF RESULT $=0$, SET TO D IF RESULT < O, SET TO 1 IF RESULT $>0$, SET TO 2 IF OVERFLOW, SET TO 3 UNCHANGED |  |  |  |  |  |  |
|  |  |  |  |  |  |  |  |  |
|  |  |  |  |  |  |  |  |  |
|  |  |  |  |  |  |  |  |  |

The zero and add decimal (ZAP) instruction moves a packed field of zeros into operand 1 and then adds the packed contents of operand 2 to the packed field of zeros in operand 1. The result replaces operand 1.

## Explicit Format:

| LABEL | $\triangle$ OPERATION $\triangle$ |  |
| :--- | :--- | :--- |
| [symbol] | ZAP | $\mathrm{d}_{1}\left(\mathrm{I}_{1}, \mathrm{~b}_{1}\right), \mathrm{d}_{2}\left(\mathrm{I}_{2}, \mathrm{~b}_{2}\right)$ |

Implicit Format:


This instruction operates in the same manner as the add decimal (AP) instruction except that a packed field of zeros is moved into operand 1 before the addition occurs. The sign of the packed field of zeros is positive. After the addition takes place the resultant sign is the same as operand 2. If operand 2 does not have a valid sign in the low order four bits, a data exception occurs. If an overflow condition occurs and the leftmost bytes are truncated, a zero result still has the sign of operand 2. In effect, the ZAP instruction replaces operand 1 with the contents of operand 2 . The length of operand 1 should be the same as, or larger than, the length of operand 2 . If the operand 1 field is not sufficient to receive all of operand 2, an overflow condition occurs. Operands 1 and 2 can have overlapping bytes when the rightmost byte of operand 1 coincides with, or is to the right of, the rightmost byte of operand 2, provided a valid sign exists in the low order four bits of operand 2.

Operational Considerations:

- Operands 1 and 2 must be in packed decimal format.
- If the length of operand 2 is larger than the length of operand 1 , the leftmost digits of operand 2 are truncated.
- If the length of operand 1 is larger than operand 2, the leftmost digits of operand 1 are zero-filled.
- Operand 2 must have à valid sign in the low order four bits.


## Example:

| LABEL | $\triangle O P E R A T I O N \triangle$ |  |
| :---: | :---: | :---: |
| 1 | 10 | 16 |
|  | ZAP | TOTAMT, YTDAMT |
|  | - |  |
|  | - |  |
| TOTAMT | DC | P'528416' $^{\prime}$ |
| Ytdamt | DC | P'215' |

TOTAMT before execution of ZAP instruction:


Packed decimal number
YTDAMT before and after execution of ZAP instruction:


In this example, the ZAP instruction moves a packed field of zeros into TOTAMT and then adds the contents of YTDAMT to TOTAMT. As you can see, the contents of YTDAMT now replaces the contents of TOTAMT. In this sample program, TOTAMT contains a year's total amount of sales, while YTDAMT contains the accumulative amount of sales. At the end of 12 months, when the maximum amount of sales for the year is reached, TOTAMT must be cleared to zero, so that the amount of sales for the first month of the next year can be accumulated.

Example:

|  | MVC | $C A L C+1(1),=P^{\prime} 1 \prime$ |
| :--- | :--- | :--- |
|  | ZAP | $C A L C+1(2), C A L C(2)$ |
|  | $\cdot$ |  |
| $C A L C$ | DC | $P^{\prime} 25124^{\prime}$ |

CALC before execution of MVC instruction:


Packed decimal number

CALC after execution of MVC instruction:

operand 2

(stored)
CALC during execution of ZAP instruction:


Packed field of zeros

CALC after execution of ZAP instruction:


Packed decimal number

In this example, operands 1 and 2 have one overlapping byte. The rightmost byte of $\mathrm{CALC}+1(2)$ (operand 1 ) is to the right of the rightmost byte of $\mathrm{CALC}(2)$ (operand 2 ). When the ZAP instruction is executed, a packed field of zeros with a positive sign is moved into operand 1. Then, the contents of operand 2 that has been saved prior to the execution of the ZAP instruction is now added to the packed field of zeros. In effect, the contents of operand 2 now replace the contents of operand 1.

# 10. Fixed-Point Binary Instructions 

### 10.1. USE OF FIXED-POINT BINARY INSTRUCTIONS

If the fixed-point binary instruction set (RX, RR, or RS) is compared to the decimal instruction set (SS or SI), you will discover that the difference between storage-to-storage type instructions and register type instructions is the location of the instruction operands. Both operands for decimal instructions are contained in main storage, while the operands for fixed-point instructions are either both in the processor or one in the processor and one in main storage. Any instruction operands located in main storage are transferred to the processor before execution. In fixed-point binary instructions, the RR type requires no transfer of operands, while the RX and RS types require transfer of only one. In decimal instructions, both operands are always transferred. This explains why execution time of fixed-point binary instructions is faster than execution time of decimal instructions.

Execution time gained by arithmetic binary instructions over decimal instructions is lost, however, in the data conversion process. Both instruction sets must convert card input data in zoned decimal format (EBCDIC) to a data format acceptable to the instruction set. Decimal instruction input data must be converted to packed decimal format; fixed-point binary instruction input data must be converted to binary format.

Conversion to packed format is faster than conversion to fixed-point binary format because binary conversion requires an additional instruction that has a slower execution time. To get input data into packed format, you use the PACK instruction; to output packed data, you must first unpack it with the UNPK or ED instruction. When converting input data to binary, the data must be packed first, then converted to binary (using the convert to binary (CVB) instruction). On output, data must be converted to packed decimal (using the convert to decimal (CVD) instruction) and then converted to unpacked or zoned decimal format. For input conversion, fixed-point binary instructions execute slower than decimal instructions. For a comparison of the execution times for decimal and fixed-point instructions, see the system hardware and software summary, UP-8203 (current version).

Fixed-point instructions should be used in programs having less input data and more arithmetic calculations, whereas decimal instructions should be used in programs having more input data and less arithmetic calculations. This is why binary instructions are used in the design of FORTRAN compilers and decimal instructions are used in the design of COBOL compilers.

There are 16 general registers located inside the processor that can be used as operands in fixed-point instructions. A decimal number ( 0 through 15) is used to reference a register. This is similar to using labels when referencing main storage locations.

For all fixed-point instructions, operand 1 always references a register with the exception of the add immediate (AI) instruction, whose operands both reference main storage locations. The operand 1 register is usually the receiving field or resultant field after an instruction is executed. For the store (ST) and convert to decimal (CVD) instructions, however, operand 2 (a main storage location) is the resultant field. In fixed-point instructions, operand 2 references either a register (RR), or a main storage location (RX or RS). The compare instructions do not have a resultant field, since they test already existing conditions and have no effect on operands 1 and 2 .

To bring data from main storage into a register, it must be compatible with the structure of the register. A register is four bytes in length and uses 32 binary bits to represent a signed binary number. The high order bit position represents the sign. A binary 1 in the high order bit position represents a negative number, whereas a binary 0 in the high order bit position represents a positive number.

REGISTER (4 bytes)


There are two ways to create data in fixed-point binary format:

1. Use the convert to binary (CVB) instruction to convert a packed decimal number to a fixed-point binary number which is placed in a register.
2. Use the define constant (DC) statement to create a constant that is defined as a half word, full word, or double word, or a constant that is aligned on a half-word, fullword, or double-word boundary. This constant is then placed in a register through execution of another instruction [i.e., Add (A), Load (L), Subtract (S)].

HALF WORD (2 bytes)

| $S$ |  |  |
| :--- | :--- | :--- | :--- |
| $l$ |  |  |
| $G$ |  | 15 |
| $N$ |  | 1 |
| 0 | 1 |  |

FULL WORD (4 bytes)


DOUBLE WORD (8 bytes)


As shown, these formats are compatible with the formats of registers. Since registers are full words ( 4 bytes), only full words or half words in main storage (or other registers) can be specified as operand 2 . When a half word value in main storage is specified as operand 2, a full 4 bytes are used when that instruction is executed. Operand 2 is expanded to 32 bits by propagating the sign bit value through the 16 high order bit positions. Expansion occurs after the operand is obtained and before insertion, comparison, or any mathematical calculations are performed with the register.

### 10.1.1. Half-Word Fixed-Point Constants

The character H is the definition type used for defining half-word fixed-point constants in main storage. The constants associated with this definition type must be enclosed within apostrophes, cannot exceed more than five decimal digits, and cannot have a value greater than $+32767\left(2^{15}-1\right)$ or less than $-32768\left(-2^{15}\right)$. Half-word constants are two bytes in length and aligned on a half-word boundary. If the constant specified does not occupy the full two bytes, it is right-justified and the high order unused bits are filled with the sign bit. Duplication factors can be used and the nominal value can be a signed or unsigned decimal number. Because the length of a half word is always two bytes, no length factor is required. If a length factor is specified, half-word boundary alignment is ignored and the specified length is allocated.

Example:

| LOC. | OBJECT CODE | LINE | SOURCE STATEMENT |  |
| :--- | :--- | :--- | :--- | :--- |
| 000002 | 39 | 4 PLUSI | DC | HLI' $+57^{\prime}$ |
| 000003 | 00 | 5 PLUS2 | DC | $H^{\prime} 57^{\prime}$ |
| 000004 | 0039 | 6 NEG1 | DC | $H^{\prime} I^{\prime}-57^{\prime}$ |
| 000006 | $C 7$ | 7 NEG2 | DC | $H^{\prime}-57^{\prime}$ |
| 000007 | 00 |  |  |  |
| 00008 | $\mathrm{FFC7}$ |  |  |  |

### 10.1.2. Full-Word Fixed-Point Constants

The character $F$ is the definition type used for defining full-word fixed-point constants in main storage. The constant associated with this definition type must be enclosed within apostrophes, cannot exceed more than 10 decimal digits, and cannot have a value greater than $+2,147,483,647\left(2^{31}-1\right)$ or less than $-2,147,483,648\left(-2^{31}\right)$. Full-word constants are four bytes in length and aligned on a full-word boundary. If the constant specified does not occupy the full four bytes, it is right-justified and leftmost unused bits are filled with the sign bit. Duplication factors can be used and the nominal value can be a signed or unsigned decimal number. Because the length of a full word is always four bytes, no length factor is required. If a length factor is specified, full-word boundary alignment is ignored and the specified length is allocated.

## Example:

| LOC. | OBJECT CODE | LINE | SOURCE STATEMENT |  |
| :--- | :--- | :--- | :--- | :--- |
| $00000 A$ | $010 F$ | 8 PLUS3 | DC | FL2'+271' |
| $00000 C$ | $0000010 F$ | 9 PLUS4 | DC | $F^{\prime} 271^{\prime}$ |
| 000010 FEF1 | 10 NEG3 | DC | $F^{\prime} 2^{\prime}-271^{\prime}$ |  |
| 000012 0000 | 11 NEG4 | DC | $F^{\prime}-271^{\prime}$ |  |
| 000014 FFFFFEFI |  |  |  |  |

### 10.1.3. Address Constants

Address constants are storage addresses that are stored as constants by using DC statements. Address constants are used to initialize base registers; thereby, providing communication between control sections of a multisection program. Unlike other types of constants, an address constant is enclosed within parenthesis. If more than one address constant is specified, they are separated by commas, and the entire sequence is enclosed within parenthesis. There are two types of address constants: half word ( Y ) and full word (A).

### 10.1.3.1. Full-Word Address Constants

This constant can be specified as an absolute, relocatable, or complex relocatable expression. It has a length of four bytes and is full-word boundary aligned. You cannot specify a value greater than $+2,147,483,647\left(2^{31}-1\right)$ or less than $-2,147,483,648\left(-2^{31}\right)$. To generate full-word address constants, use the DC statements with the character $A$ as the definition type and the expressions specified enclosed within parenthesis. You can also generate full-word address constants as literals. The address of these expressions are stored in consecutive full words in main storage. However, if a length factor is specified, full-word boundary alignment is ignored and the specified length is allocated.

Example:


### 10.1.3.2. Half-Word Address Constants

This constant can be specified as an absolute, relocatable, or complex relocatable expression. It has a length of two bytes and is half-word boundary aligned. You cannot specify a value greater than $+32767\left(2^{15}-1\right)$ or less than $-32768\left(-2^{15}\right)$. To generate halfword address constants, use the DC statements with the character $Y$ as the definition type and the expressions specified enclosed within parenthesis. You can also generate halfword address constants as literals. The addresses of these expressions are stored in consecutive half words in main storage. However, if a length factor is specified, half-word boundary alignment is ignored and the specified length is allocated.

| LOC. | OBJECT CODE | LINE |  | SOURCE STATEMENT |  |
| :---: | :---: | :---: | :---: | :---: | :---: |
| 000002 | 500C |  | Value | DC | PL2'500' |
| 000004 | 00000001 |  | NUM | DC | $\mathrm{F}^{\prime \prime}$ |
| 000008 | F3F6F2 |  | POS | DC | X'F3F6F2' |
| 00000B | 60 |  | NEG | DC | CLI'-8' |
| 00000C | F6F2F4F7C0 |  | ZONE | DC | ZL5'62470' |
| 000011 | 00 |  |  |  |  |
| 000012 | 000B |  | ADCONYI | DC | Y(NEG, POS ) |
| 000014 | 0008 |  |  |  |  |
| 000016 |  |  |  |  |  |
| 000016 | 0116 |  | ADCONY2 | DC | $Y(*+256,600)$ |
| 000018 | 0258 |  |  |  |  |
| 00001A | 0008 |  | ADCONY 3 | DC | Y (VALUE +6 ) |
| 00001C |  |  |  |  |  |
| 00001C | 0019000A |  | ADCONY4 | DC | Y (25,ZONE-VALUE, NUM, POS +4 ) |
| 000020 | 0004 |  |  |  |  |
| 000022 | 000C |  |  |  |  |
| 000024 |  |  |  |  |  |

### 10.1.4. Representation of Positive and Negative Fixed-Point Binary Numbers

Binary ones and zeros, with relation to their positions in a string of bits, represent values expressed in powers of two (see Appendix C.3). The powers of two increase from right to left (Figure 10-1). A zero (0) bit indicates no value and a one (1) bit indicates that a value exists. By adding all the powers of two that correspond to one bits, you can determine the decimal equivalence for a positive binary number. A zero bit in the high order bit or any unused high order bits signify a positive binary number.


Figure 10-1. Comparison of Binary Numbers and Values Expressed in Powers of 2

Negative binary numbers are indicated by a 1 bit in the high order bit position or any unused high order bit positions. The remaining portion contains the negative binary number but in twos complement form. To change a positive binary number into twos complement form:

- reverse the bits; and
- add one to the rightmost or low order bit position.

| 0001101011000101 | positive binary number <br> (decimal $+6,853$ ) |
| ---: | :--- |
| 1110010100111010 <br> +1 | reversed bits <br> add 1 |
| 1110010100111011 | binary number in twos complement form <br> (decimal $-6,853$ ) |

10.2. ADD (A)


The add ( A ) instruction algebraically adds the full-word main storage contents of operand 2 to the contents in the operand 1 register and stores the sum in operand 1.

Explicit Format:

| LABEL | $\triangle$ OPERATION $\triangle$ |  |
| :--- | :--- | :--- |
| [symbol] | A | $\mathrm{r}_{1}, \mathrm{~d}_{2}\left(\mathrm{x}_{2}, \mathrm{~b}_{2}\right)$ |

Implicit Format:

| LABEL | $\triangle$ OPERATION $\triangle$ |  | OPERAND |
| :--- | :--- | :--- | :--- |
| [symbol] | A | $\mathrm{r}_{1}, \mathrm{~s}_{2}\left(\mathrm{x}_{2}\right)$ |  |

## Operational Considerations:

- Any of the general registers ( 0 through 15) can be used as operand 1.
- Operand 2 must either be defined as a full word or aligned on a full-word boundary.
- If the sum exceeds 31 bit positions, an overflow condition occurs.

Example:


Register 6 before execution of $A$ instruction:

| 0000 | 0000 | 0000 | 0000 | 0000 | 0000 | 0000 | 0000 |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 |

> binary
> hex

FULLWORD before and after execution of A instruction:

| 0000 | 0000 | 0000 | 0000 | 0000 | 0001 | 0000 | 1111 |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| 0 | 0 | 0 | 0 | 0 | 1 | 0 | $F$ |

## binary <br> hex

Register 6 after execution of $A$ instruction:

binary
hex

In this example, the SR instruction subtracts the content of register 6 from itself, clearing it to zero. Then the content of FULLWORD is added to the content of register 6 . The result replaces the content of the operand 1 register.

### 10.3. ADD (AR)



Condition Codes

```
IF RESULT = 0, SET TO O
```

IF RESULT = 0, SET TO O
|if RESULT<0, SET TO 1
|if RESULT<0, SET TO 1
|if RESULT>0, SET TO 2
|if RESULT>0, SET TO 2
WIF OVERFLOW, SET TO 3
WIF OVERFLOW, SET TO 3 $\square$ UNCHANGED

```
\begin{tabular}{|c|c|}
\hline \multicolumn{2}{|r|}{Possible Program Exceptions} \\
\hline ADDRESSING
data (INVALIDSIGN/DIGIT)
decimal divide
DECIMAL OVERFLOW
EXECUTE
EXPONENT OVERFLOW
EXPONENT UNDERFLOW
FIXED-POINT DIVIDE
FIXED-POINT OVERFLOW
FLOATING-POINT DIVIDE
operation & \begin{tabular}{l}
PROTECTION
SIGNIFICANCE
SPECIFICATION:
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 \\
OP 2 NOT ON DOUBLE-WORD \\
BOUNDARY \\
OP 1 NOT EVEN NUMBERED REGISTER \\
OP 1 NOT ODD NUMBERED REGISTER \\
NONE
\end{tabular} \\
\hline
\end{tabular}

The add (AR) instruction algebraically adds the contents of the operand 2 register to the contents of the operand 1 register and stores the sum in operand 1.

Explicit and Implicit Format:
\begin{tabular}{c|c|c} 
LABEL & \(\triangle\) OPERATION \(\triangle\) & \\
\hline [symbol] & AR & \(r_{1}, r_{2}\)
\end{tabular}

\section*{Operational Considerations:}
- Any of the general registers (0 through 15) can be used as operands 1 and 2 .
- If the sum exceeds 31 bit positions, an overflow condition occurs.

Example:
\begin{tabular}{|c|c|c|c|}
\hline \multirow[t]{2}{*}{LABEL} & \multicolumn{2}{|l|}{\(\triangle O P E R A T I O N \triangle\)} & \multirow[t]{2}{*}{OPERAND} \\
\hline & 10 & 16 & \\
\hline & L & 5,NUMI & \\
\hline & L & 6,NuM2 & \\
\hline & AR & 5,6 & \\
\hline & - & & \\
\hline & & & \\
\hline NUMI & DC & \(\mathrm{F}^{\prime 2} 2{ }^{\prime}\) & \\
\hline NUM2 & DC & F'16' & \\
\hline
\end{tabular}

Register 5 before execution of AR instruction:

binary
hex

Register 6 before and after AR instruction:
\begin{tabular}{|c|c|c|c|c|c|c|c|c|}
\hline 0000 & 0000 & 0000 & 0000 & 0000 & 0000 & 0001 & 0000 \\
\hline 0 & 0 & 0 & 0 & 0 & 0 & 1 & 0 \\
\hline
\end{tabular}

> binary
hex

Register 5 after execution of AR instruction:


\section*{binary}
hex

In this example, the contents of NUM1 is loaded into register 5 and the contents of NUM2 is loaded into register 6. Then, the contents of register 6 is added to the contents of register 5 . The result is placed in register 5 (operand 1). Notice that both NUM1 and NUM2 are fullwords.

\subsection*{10.4. ADD HALF WORD (AH)}
\begin{tabular}{|c|c|c|c|}
\hline \multicolumn{4}{|c|}{ General } \\
\hline OPCODE & FORMAT \\
TYPE & \begin{tabular}{l} 
OBJECT \\
INST. \\
LGTH. \\
(BYTES)
\end{tabular} \\
\hline MNEM. & HEX. & \\
\hline \(\mathbf{A H}\) & 4A & RX & \(\mathbf{4}\) \\
\hline
\end{tabular}
\begin{tabular}{|c|c|}
\hline \multicolumn{2}{|r|}{Possible Program Exceptions} \\
\hline ADDRESSING
DATA (INVALIDSIGN/DIGIT)
DECIMAL DIVIDE
DECIMAL OVERFLOW
EXECUTE
EXPONENT OVERFLOW
EXPONENT UNDERFLOW
FIXED-POINT DIVIDE
FIXED-POINT OVERFLOW
FLOATING-POINT DIVIDE
operation & \begin{tabular}{l}
PROTECTION
SIGNIFICANCE \\
SPECIFICATION: \\
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 \\
OP 2 NOT ON DOUBLE-WORD \\
BOUNDARY \\
OP 1 NOT EVEN NUMBERED REGISTER \\
OP 1 NOT ODD NUMBERED REGISTER \\
NONE
\end{tabular} \\
\hline
\end{tabular}

The add half-word \((\mathrm{AH})\) instruction algebraically adds the contents of operand 2 to the contents of the operand 1 register and puts the sum in operand 1.

\section*{Explicit Format:}
\begin{tabular}{c|c|l} 
LABEL & \(\triangle\) OPERATION \(\triangle\) & \\
\hline [symbol] & AH & \(\mathrm{r}_{1}, \mathrm{~d}_{2}\left(\mathrm{x}_{2}, \mathrm{~b}_{2}\right)\)
\end{tabular}

Implicit Format:
\begin{tabular}{l|l|ll} 
LABEL & \(\triangle\) OPERATION \(\triangle\) & & OPERAND \\
\hline [symbol] & AH & \(\mathrm{r}_{1}, \mathrm{~s}_{2}\left(\mathrm{x}_{2}\right)\)
\end{tabular}

Operand 2 is two bytes in length (16-bit signed integer) and is located in main storage. Before operand 2 is added to the operand 1 register, operand 2 is temporarily expanded to 32 bits by propagating the sign bit through the high order 16 bit positions. Then all 32 bits of operand 2 are added to the 32 bits of operand 1 . The result is placed in operand 1 . If the sum exceeds 31 bits, an overflow condition occurs.

\section*{Operational Considerations:}
- Operand 2 must be either defined as a half word or half-word boundary aligned.
- Any of the general registers ( 0 through 15 ) can be used as operand 1.
- A fixed-point overflow condition can occur.

\section*{Example:}
```

LABEL \triangleOPERATION\triangle OPERAND
1 10 16

```
\begin{tabular}{cc}
\hline L & 5, FULLWORD \\
AH & 5,HALFWORD \\
\(\cdot\) & \\
FULLWORD DC & F' \(^{\prime} 32^{\prime}\) \\
HALFWORD DC & H' \(^{\prime} 16^{\prime}\)
\end{tabular}

Register 5 before execution of AH instruction:
\begin{tabular}{|c|c|c|c|c|c|c|c|}
\hline 0000 & 0000 & 0000 & 0000 & 0000 & 0000 & 0010 & 0000 \\
\hline 0 & 0 & 0 & 0 & 0 & 0 & 2 & 0 \\
\hline
\end{tabular}

\section*{binary \\ hex}

HALFWORD before and after execution of \(A H\) instruction:


Register 5 after execution of AH instruction:
\begin{tabular}{|c|c|c|c|c|c|c|c|}
\hline 0000 & 0000 & 0000 & 10000 & 0000 & 0000 & 0011 & 0000 \\
\hline 0 & 0 & 0 & 0 & 0 & 0 & 3 & 0 \\
\hline
\end{tabular}

\section*{binary}
hex

In this example, the content of FULLWORD is loaded into register 5. Then the content of HALFWORD is added to the content of register 5 . The result is placed in register 5 (operand 1). If the sum exceeds 31 bits, an overflow condition occurs.

\subsection*{10.5. ADD IMMEDIATE (AI)}


The add immediate (AI) instruction algebraically adds the 1 -byte immediate data in operand 2 to the half word value in operand 1 . The sum is placed in operand 1.

\section*{Explicit Format:}
\begin{tabular}{l|l|l} 
LABEL & DOPERATION \(\triangle\) & \\
\hline [symbol] & AI & \(\mathbf{d}_{1}\left(\mathrm{~b}_{1}\right), \mathrm{i}_{2}\)
\end{tabular}

Implicit Format:
\begin{tabular}{l|l|l} 
LABEL & \(\triangle\) OPERATION \(\Delta\) & OPERAND \\
\hline [symbol] & AI & \(\mathbf{s}_{1}, \mathbf{i}_{2}\)
\end{tabular}

Operand 1 must be either defined as a half word or is half-word boundary aligned. Operand 2 must be a 1 -byte self-defining term. Before operand 2 is added to the half word in operand 1 , operand 2 is temporarily expanded to 16 bits by propagating the sign bit through the high order 8 bit positions. Then all 16 bits in operand 2 are added to the 16 bits in operand 1. The result is placed in operand 1 . If the sum exceeds 15 bit positions, an overflow condition occurs.

Operational Considerations:
- Operand 1 must be either defined as a half word or aligned on a half-word boundary.
- During execution of the Al instruction, operand 2 is temporarily expanded to 16 bit positions. The leftmost eight bits are the same as the sign bit.
- Operand 2 must be a 1 -byte self-defining term (see 4.4).
- You may not specify an immediate value greater than +127 ( \(2^{7}-1\) ) or less than -128 (-27) in operand 2.
- If the sum exceeds 15 bit positions, an overflow condition can occur.

Example:
```

LABEL \triangleOPERATIONA
1 10}1
OPERAND

```

AI STORAGE, 1
.
STORAGE DC H'3'

STORAGE before execution of Al instruction:


Operand 2 immediate before and after execution of Al instruction:


STORAGE after execution of AI instruction:

binary
hex

In this example, the immediate value in operand 2 is added to the half-word value in STORAGE. The result replaces the contents of STORAGE.

\section*{C}
10.6. COMPARE (C)
\begin{tabular}{|c|c|c|c|c|c|}
\hline \multicolumn{4}{|c|}{General} & \multicolumn{2}{|r|}{Possible Program Exceptions} \\
\hline \multicolumn{2}{|l|}{OPCODE} & \multirow[t]{2}{*}{FORMAT
TYPE} & \multirow[t]{2}{*}{OBJECT INST. LGTH. (BYTES)} & \multirow[t]{5}{*}{ADDRESSING
data (invalid sign/digit)
decimal divide
DECIMAL OVERFLOW
execute
EXPONENT OVERFLOW
Exponent underflow
fixed-point divide
FIXED-POINT OVERFLOW
floating-point divide
operation} & \multirow[t]{2}{*}{PROTECTION
significance
SPECIFICATION:} \\
\hline MNEM. & HEX. & & & & \\
\hline C & 59 & RX & 4 & & \(\square\) OP 1 NOT ON HALF WORD BOUNDARY \\
\hline \multicolumn{4}{|c|}{Condition Codes} & & OP 2 NOT ON HALF-WORD BOUNDARY OP 2 NOT ON FULL-WORD BOUNDARY \\
\hline \multicolumn{4}{|l|}{IF r \(\mathrm{r}_{1}=\) OPERAND 2, SET TO O IF r 1 <OPERAND 2, SET TO 1 IF r \(1>\) OPERAND 2 , SET TO 2
if overflow, SET to 3 unchanged} & & \begin{tabular}{l}
OP 2 NOT ON DOUBLE WORD BOUNDARY \\
op 1 not even numbered register \\
op 1 not odd numbered register
NONE
\end{tabular} \\
\hline
\end{tabular}

The compare ( C ) instruction algebraically compares the contents in the operand 1 register to the full word in operand 2 . The result determines the setting of the condition code. (See condition code settings, 8.5.)

Explicit Format:
\begin{tabular}{l|l|l} 
LABEL & \(\triangle\) OPERATION \(\triangle\) & \\
\hline [symbol] & C & \(\mathrm{r}_{1}, \mathrm{~d}_{2}\left(\mathrm{x}_{2}, \mathrm{~b}_{2}\right)\)
\end{tabular}

Implicit Format:


The operand 1 register is compared to a 32-bit signed integer (operand 2) located on a fullword boundary in main storage. The result of the comparison determines the setting of the condition code, bits 34 and 35 of the PSW. (See 8.1.)

If operand \(1=\) operand 2 , set to 0 .
If operand \(1<\) operand 2 , set to 1 .
If operand \(1>\) operand 2 , set to 2 .

Usually, a conditional branch instruction tests the resulting condition code for an equal to zero, less than zero, or greater than zero condition. If the condition is met, a branch takes place. If not the program continues processing as shown in the following coding instruction.

\section*{Operational Considerations:}
- Any of the general registers ( 0 through 15 ) can be used as operand 1.
- Operand 2 must be either defined as a full word or aligned on a full-word boundary.
- Neither operand is changed by the execution of the instruction.

Example:
\begin{tabular}{|c|c|c|}
\hline LABEL & \multicolumn{2}{|l|}{\(\triangle\) OPERATIOND} \\
\hline 1 & 10 & 16 \\
\hline & SR & 7,7 \\
\hline & L & 5,AMOUNT \\
\hline & C & 5,FULLWORD \\
\hline & BE & ROUTINE \\
\hline & A & \(6,=\mathrm{F}^{\prime} 1 \mathrm{l}\) \\
\hline & - & \\
\hline & - & \\
\hline ROUTINE & AR & 7,5 \\
\hline & - & \\
\hline & - & \\
\hline FULLWORD & DC & F'32' \\
\hline AMOUNT & DC & F'32' \\
\hline
\end{tabular}

Register 5 before and after execution of C instruction:
\begin{tabular}{|c|c|c|c|c|c|c|c|}
\hline 0000 & 0000 & 0000,0000 & 0000,0000 & 0010 & 0000 \\
\hline 0 & 0 & 0 & 0 & 0 & 0 & 2 & 0 \\
\hline
\end{tabular}\(\quad \quad \quad\) binary

FULLWORD before and after execution of C instruction:
\begin{tabular}{|c|c|c|c|c|c|c|c|}
\hline 0000 & 0000 & 0000 & 0000 & 0000 & 0000 & 0010 & 0000 \\
\hline 0 & 0 & 0 & 0 & 0 & 0 & 2 & 0 \\
\hline
\end{tabular}

\section*{binary}
hex

In this example, the full word in AMOUNT is loaded into register 5. Then, the content of register 5 is compared to the full word in FULLWORD. Since they compare equally, the condition code is set \(O\) and a branch to the instruction labeled ROUTINE takes place. If they do not compare equally, the \(A\) instruction following the \(B E\) instruction is executed and the program continues processing.

\subsection*{10.7. COMPARE (CR)}


The compare (CR) instruction algebraically compares the contents in the operand 1 register to the contents in the operand 2 register. The result determines the setting of the condition code. (See condition code settings, 8.5.)

Explicit and Implicit Format:
\begin{tabular}{c|c|cc} 
LABEL & \(\triangle\) OPERATION \(\triangle\) & & OPERAND \\
\hline [symbol] & CR & \(r_{1}, r_{2}\) &
\end{tabular}

The 32 bits of operand 1 are compared to the 32 bits of operand 2. The result determines the setting of the condition code, bits 34 and 35 of the PSW. (See 8.1.)

If operand \(1=\) operand 2 , set to 0 .
If operand \(1<\) operand 2 , set to 1 .
If operand \(1>\) operand 2 , set to 2 .
Usually, a conditional branch instruction tests the resulting condition code for an equal to, less than, or greater than condition. If the condition is met, a branch takes place accordingly. If not, the program continues processing as shown in the following coding instruction.

Operational Considerations:
- Any of the general registers ( 0 through 15 ) can be used as operands 1 and 2.
- Neither operand is changed by the instruction.

\section*{Example:}
\begin{tabular}{|c|c|c|c|}
\hline \multirow[t]{2}{*}{\[
\begin{aligned}
& \text { LABEL } \\
& 1
\end{aligned}
\]} & \multicolumn{2}{|l|}{\(\triangle O P E R A T I O N \triangle ~\)} & \multirow[t]{2}{*}{OPERAND} \\
\hline & 10 & 16 & \\
\hline & SR & 7,7 & \\
\hline & L & 5,AMOUNT & \\
\hline & L & 6,VALUE & \\
\hline & CR & 5,6 & \\
\hline & BH & ROUTINE & \\
\hline & AR & 7,5 & \\
\hline & - & & \\
\hline & - & & \\
\hline ROUTINE & Al & ERCNT, 1 & \\
\hline & - & & \\
\hline & - & & \\
\hline AMOUNT & DC & F'32' & \\
\hline value & DC & F'32' & \\
\hline ERCNT & DC & \(H^{\prime} \emptyset^{\prime}\) & \\
\hline
\end{tabular}

Register 5 before and after execution of CR instruction:
\begin{tabular}{|c|c|c|c|}
\hline 000010000 & 000010000 & 0000,0000 & 0010,0000 \\
\hline 010 & 0 : 0 & 010 & 2 l \\
\hline
\end{tabular}

Register 6 before and after execution of CR instruction:


In this example, the full word in AMOUNT is loaded into register 5 and the full word in VALUE is loaded into register 6 . Then the content of register 5 is compared to the content of register 6 . Since they compare equally, the condition code is set to 0 . The next branch instruction ( BH ) tests for a greater than (high) condition. Since both registers compare equally, no branch is taken and the instruction following the BH instruction (AR) is executed and the program continues processing.

\subsection*{10.8. COMPARE HALF WORD (CH)}


The compare half word \((\mathrm{CH})\) instruction algebraically compares the contents in the operand 1 register to the half word in operand 2 . The result of the comparison determines the setting of the condition code.

\section*{Explicit Format:}
\begin{tabular}{c|c|l} 
LABEL & \(\triangle\) OPERATION \(\triangle\) & \\
\hline [symbol] & CH & \(\mathrm{r}_{1}, \mathrm{~d}_{2}\left(\mathrm{x}_{2}, \mathrm{~b}_{2}\right)\)
\end{tabular}

\section*{Implicit Format:}
\begin{tabular}{c|c|c} 
LABEL & \(\triangle\) OPERATION \(\triangle\) & \\
\hline [symbol] & CH & \(\mathrm{r}_{1}, \mathrm{~s}_{\mathbf{2}}\left(\mathrm{x}_{2}\right)\)
\end{tabular}

Operand 2 is two bytes in length (16-bit signed integer) and is located in main storage. Before operand 2 is compared with the operand 1 register, operand 2 is temporarily expanded to 32 bits by propagating the sign bit through the high order 16 bit positions. Then all 32 bits of operand 1 are compared to the 32 bits in operand 2. The result determines the setting of the condition code, bits 34 and 35 of the PSW. (See 8.1.)

If operand \(1=\) operand 2 , set to 0 .
If operand \(1<\) operand 2 , set to 1 .
If operand \(1>\) operand 2 , set to 2 .

Usually, a conditional branch instruction tests the condition code for an equal to, less than, or greater than condition. If the condition is met, a branch takes place accordingly. If not, the program continues processing as shown in the following coding instruction.

Operational Considerations:
- Any of the general registers ( 0 through 15 ) can be used as operand 1.
- Operand 2 must be either defined as a half word or aligned on a half-word boundary.
- Neither operand is permanently changed by the execution of the instruction.

Example:
\begin{tabular}{|c|c|c|c|}
\hline LABEL & \multicolumn{2}{|l|}{\(\triangle O P E R A T I O N \triangle\)} & OPERAND \\
\hline 1 & 10 & 16 & \\
\hline & L & 5,AMOUNT & \\
\hline & CH & 5,HALFWORD & \\
\hline & BH & ROUTINE & \\
\hline & AR & 8,5 & \\
\hline ROUTINE & A & 6, =F11 & \\
\hline & - & & \\
\hline & & & \\
\hline AMOUNT & DC & F'32' & \\
\hline HALFWORD & DC & H'16' & \\
\hline
\end{tabular}

Register 5 before and after execution of CH instruction:


HALFWORD before and after execution of CH instruction:


In this example, the full word in AMOUNT is loaded into register 5. Then, the content of register 5 is compared to the half word in HALFWORD. Since the content of register 5 is greater than the content of HALFWORD, the condition code is set to 2 . The next branch instruction ( BH ) tests for a greater than (high) condition. Since a greater than condition exists, a branch to the instruction labeled ROUTINE taken place.

\subsection*{10.9. CONVERT TO BINARY (CVB)}


The convert to binary (CVB) instruction converts the packed decimal contents of the double word in operand 2 to its binary equivalent and puts the result in the operand 1 register.

Explicit Format:


Implicit Format:
\begin{tabular}{l|l|l} 
LABEL & \(\triangle\) OPERATION \(\triangle\) & \\
\hline [symbol] & CVB & \(r_{1}, s_{2},\left(x_{2}\right)\)
\end{tabular}

The CVB instruction converts a packed decimal number into a binary number. The operand 1 register contains the resulting binary number ( 4 bytes in length) and operand 2 is a packed number ( 8 bytes in length) aligned on a double-word boundary. Operand 2 is checked for a valid sign in the low order four bits. The remaining 60 bits represent a decimal value not exceeding 15 decimal digits. The largest decimal number that can be converted is \(+2,147,483,647\left(2^{31}-1\right)\) and the smallest is \(-2,147,483,678\left(-2^{31}\right)\). Any decimal number outside this range causes a fixed-point decimal divide. The result of the conversion is placed in the operand 1 register. The sign value (low order four bits) of the packed decimal number in operand 2 becomes the sign value (high order bit or bits) of the binary number in the operand 1 register.

\section*{Operational Considerations:}
- Any of the general registers ( 0 through 15 ) can be used as operand 1.
- Operand 2 must contain a packed decimal number aligned on a double-word boundary.
- If the sign value of the packed decimal number in operand 2 is positive, the sign value of the binary number in operand 1 is positive.
- If the sign value of the packed decimal number in operand 2 is negative, the binary number in operand 1 is represented in two's complement form and the sign value is negative.
- The condition code remains unchanged.
- There is no conversion between EBCDIC and binary. EBCDIC data must first be packed, then converted to binary.

\section*{Example:}
\begin{tabular}{|c|c|c|c|}
\hline \multirow[t]{2}{*}{\[
\begin{aligned}
& \text { LABEL } \\
& 1
\end{aligned}
\]} & \multicolumn{2}{|l|}{OOPERATIONA} & \multirow[t]{2}{*}{OPERAND} \\
\hline & 10 & 16 & \\
\hline & SR & 7,7 & \\
\hline & SR & 5,5 & \\
\hline & L & 6,=F'1øø' & \\
\hline & PACK & DBLWDP, AMT (3) & \\
\hline & CVB & 5,DBLWDP & \\
\hline & CR & 5,6 & \\
\hline & BH & ERRTN & \\
\hline & AR & 7,5 & \\
\hline & - & & \\
\hline & - & & \\
\hline ERRTN & A & 4, =F'11 & \\
\hline & - & & \\
\hline & - & & \\
\hline DBLWDP & DS & D & \\
\hline AMT & DC & ZL3'428' & \\
\hline
\end{tabular}

Register 5 before execution of CVB instruction:
\begin{tabular}{|c|c|c|c|c|c|c|c|}
\hline 000010000 & 0000 & 0000 & 0000 & 0000 & 0000 & 000 \\
\hline 0 & 0 & 0 & 0 & 0 & 0 & 0 & 0 \\
\hline
\end{tabular}

\footnotetext{
binary
hex
}

DBLWDP before and after execution of CVB instruction:


Packed decimal number

Register 5 after execution of CVB instruction:


In this example, the SR instruction cleared both register 5 and 7 to zero by subtracting the contents of the registers from themselves. Then, a full-word value of 100 is loaded into register 6. The contents of AMT is packed into DBLWDP and the CVB instruction converts the packed decimal value into its binary equivalent which replaces the contents of register 5 . Register 5 is then compared to register 6 . Since the value of the contents in register 5 is greater than that of register 6, the condition code is set to 2 . The BH instruction then tests for a greater than condition and a branch to the instruction labeled ERRTN takes place. If the condition code is not 2, no branch takes place and the program continues processing with the instruction following the branch.

\section*{CVD}

\subsection*{10.10. CONVERT TO DECIMAL (CVD)}
\begin{tabular}{|c|c|c|c|}
\hline \multicolumn{4}{|c|}{ General } \\
\hline OPCODE & FORMAT & \begin{tabular}{l} 
OBJECT \\
INST. \\
TYPE
\end{tabular} \\
\begin{tabular}{c|c|c|} 
LGTH. \\
(BYTES)
\end{tabular} \\
\hline MNEM. & HEX. & \\
\hline CVD & \(\mathbf{4 E}\) & RX & \(\mathbf{4}\) \\
\hline
\end{tabular}
\begin{tabular}{|c|c|}
\hline \multicolumn{2}{|r|}{Possible Program Exceptions} \\
\hline \begin{tabular}{l}
ADDRESSING \\
DATA (INVALID SIGN/DIGIT) \\
DECIMAL DIVIDE \\
DECIMAL OVERFLOW \\
EXECUTE \\
EXPONENT OVERFLOW \\
EXPONENT UNDERFLOW \\
FIXED-POINT DIVIDE \\
FIXEDPOINT OVERFLOW \\
FLOATING-POINT DIVIDE \\
OPERATION
\end{tabular} & \begin{tabular}{l}
PROTECTION
SIGNIFICANCE
SPECIFICATION:
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 \\
OP 2 NOT ON DOUBLE-WORD \\
BOUNDARY \\
OP 1 NOT EVEN NUMBERED REGISTER \\
OP 1 NOT ODD NUMBERED REGISTER \\
NONE
\end{tabular} \\
\hline
\end{tabular}

The convert to decimal (CVD) instruction converts the binary number in the operand 1 register into its packed decimal equivalence and stores the result in the double word in operand 2.

Explicit Format:
\begin{tabular}{c|l|l} 
LABEL & \(\triangle\) OPERATION \(\Delta\) & \\
\hline [symbol] & CVD & \(\mathrm{r}_{1}, \mathrm{~d}_{2}\left(\mathrm{x}_{2}, \mathrm{~b}_{2}\right)\)
\end{tabular}

Implicit Format:


The CVD instruction converts a binary value into a packed decimal value. Operand 1 register contains the binary value ( 4 bytes) and operand 2 contains a double-word field in packed decimal format ( 8 bytes). The largest decimal number that can be represented in binary in the operand 1 register is \(+2,147,483,647\left(2^{31}-1\right)\) and the smallest is \(-2,147,483,648\left(-2^{31}\right)\). Since the number to be converted is a 32 -bit signed integer from a register and there are 15 decimal digits available for its decimal equivalent, an overflow condition cannot occur.

The sign value (high order bit or bits) of the binary number in the operand 1 register becomes the sign value (low order four bits) of the packed decimal number in operand 2. The result of the conversion is placed in the doubleword of operand 2. Note that the CVD instruction is one of the few instructions that has operand 1 as the sending field and operand 2 as the receiving field.

Operational Considerations:
- Any of the general registers ( 0 through 15 ) can be used as operand 1.
- Operand 2 must be either defined as a double word or aligned on a double-word boundary.
- If the sign value of the binary number is positive, the sign value of the decimal number is positive.
- If the sign value of the binary number represented in two's complement form is negative, the sign value of the decimal number is negative.
- The condition code remains unchanged.
- The result is stored in operand 2, unlike most instructions, where operand 1 is the receiving field.

\section*{Example:}
\begin{tabular}{|c|c|c|c|}
\hline LABEL & \(\triangle\) PPER & & OPERAND \\
\hline 1 & 10 & 16 & \\
\hline & SR & 7,7 & \\
\hline & PACK & DBLEWRD, CARDIN+9(3) & \\
\hline & CVB & 4,DBLEWRD & \\
\hline & AR & 7,4 & \\
\hline & BZ & NOPAY & \\
\hline & CVD & 4, DBLEWRD & \\
\hline & ZAP & TOTHRS, DBLEWRD & \\
\hline & - & & \\
\hline & - & & \\
\hline NOPAY & A & 9, =F'1' & \\
\hline & - & & \\
\hline & - & & \\
\hline CARDIN & DC & CL8ø'SMITH,J. 480 WKTOT & EXEMPT X' \\
\hline DBLEWRD & DS & D & \\
\hline TOTHRS & DS & PL3 & \\
\hline
\end{tabular}

DBLEWRD before execution of CVD instruction:
\begin{tabular}{|l|l|l|l|l|l|l|l|l|l|l|l|l|l|l|l|}
\hline 0 & 0 & 0 & 0 & 0 & 0 & 0 & 0 & 0 & 0 & 0 & 0 & 4 & 8 & 0 & \(c\) \\
\hline
\end{tabular}

Packed decimal

Register 4 before execution of CVD instruction:


DBLEWRD after execution of CVD instruction:
\begin{tabular}{|c|c|c|c|c|c|c|c|c|}
\hline \begin{tabular}{l|l|l}
0 & 0
\end{tabular} & 0 : 0 & \begin{tabular}{l|l}
0 & 0
\end{tabular} & 0 1 0 & \begin{tabular}{l|l}
0 & 0 \\
\hline
\end{tabular} & 0 O & \(4 \mathrm{l\mid l}\) & 0 O C & Packed decima \\
\hline
\end{tabular}

In this example, register 7 is cleared to zero. A field from card input (CARDIN+9), which is EBCDIC and in zoned decimal format, is packed into DBLEWRD. The CVB instruction then converts the packed decimal number in DBLEWRD into its binary equivalent and puts the result into register 4 . The content of register 4 is added to register 7 . The condition code is set to 2 , since the result of the addition is greater than zero. The next branch instruction (BZ) tests for an equal-to-zero condition. Since that condition does not exist, no branch takes place and the instruction following the branch instruction is executed. The CVD instruction then converts the contents of register 4 into its decimal equivalent and puts the result into DBLEWRD. The ZAP instruction clears TOTHRS to zero and adds the packed decimal number in DBLEWRD to TOTHRS. (This is an example where truncation is beneficial.)

\subsection*{10.11. DIVIDE (D)}
\begin{tabular}{|c|c|c|c|}
\hline \multicolumn{4}{|c|}{General} \\
\hline \multicolumn{2}{|l|}{OPCODE} & \multirow[t]{2}{*}{FORMAT TYPE} & \multirow[t]{2}{*}{} \\
\hline MNEM. & HEX. & & \\
\hline D & 5D & RX & 4 \\
\hline \multicolumn{4}{|c|}{Condition Codes} \\
\hline \multicolumn{4}{|l|}{IF RESULT \(=0\), SET TO 0 if result <0, Set to 1 if result \(>0\) o, set to 2 if overflow, set to 3 unchanged} \\
\hline
\end{tabular}
\begin{tabular}{|c|c|}
\hline \multicolumn{2}{|r|}{Possible Program Exceptions} \\
\hline ADDRESSING
DATA (INVALID SIGN/DIGIT)
DECIMAL DIVIDE
DECIMAL OVERFLOW
EXECUTE
EXPONENT OVERFLOW
EXPONENT UNDERFLOW
FIXED-POINT DIVIDE
FIXED-POINT OVERFLOW
FLOATING-POINT DIVIDE
OPERATION & \begin{tabular}{l}
PROTECTION
SIGNIFICANCE \\
SPECIFICATION: \\
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 OP 2 NOT ON DOUBLE-WORD BOUNDARY OP 1 NOT EVEN NUMBERED REGISTER OP 1 NOT ODD NUMBERED REGISTER
NONE
\end{tabular} \\
\hline
\end{tabular}

The divide (D) instruction algebraically divides the double word in the operand 1 register pair (dividend) by the fullword in operand 2 (divisor) and puts the result (quotient and remainder) in operand 1.

\section*{Explicit Format:}
\begin{tabular}{l|l|l} 
LABEL & \(\triangle\) OPERATION \(\Delta\) & \\
\hline [symbol] & D & \(\mathrm{r}_{1}, \mathrm{~d}_{2}\left(\mathrm{x}_{2}, \mathrm{~b}_{2}\right)\)
\end{tabular}

\section*{Implicit Format:}
\begin{tabular}{l|l|l} 
LABEL & \(\triangle\) OPERATION \(\triangle\) & \\
\hline [symbol] & D & \(\mathrm{r}_{1}, \mathrm{~s}_{2}\left(\mathrm{x}_{2}\right)\)
\end{tabular}

Operand 1 consists of an even-odd pair of contiguous registers, where the even-numbered register, since it is the lower numbered register, is specified as operand 1. Every time the even-numbered operand 1 is referenced in the \(D\) instruction, both registers are used. The dividend occupies the register pair as a doubleword value with the high order bit or bits as the sign value. Operand 2 must be either defined as a full word in main storage, or aligned on a full-word boundary. The resulting quotient occupies the odd-numbered register as a full-word value with its sign determined algebraically. The remainder occupies the even-numbered register, also as a full-word value with its sign the same as the dividend. If the values of the divisor and dividend cause the quotient to be larger than a 32 -bit signed integer, a fixed-point divide program exception occurs, no division takes place, and the dividend remains unchanged.

To load a value (dividend) into an even-odd register pair, use the load multiple (LM) instruction (see 10.16). If the value (dividend) can be contained in one register, it must be loaded into the odd-numbered register only. This can be done through the use of the load (L), load register (LR), or load halfword (LH) instructions. The even-numbered register must be cleared before execution of the \(D\) instruction.

\section*{Operational Considerations:}
- Operand 1 consists of an even-odd pair of registers located in consecutive order in the processor.
- Operand 1 aiways references the even-numbered register.
- The dividend occupies both registers. After the \(D\) instruction is executed, the quotient occupies the odd-numbered register, and the remainder occupies the even-numbered register.
- Operand 2 must be either defined as a full word or aligned on a full-word boundary.
- If operand 1 does not reference an even-numbered register, a specification exception occurs.
- The condition code remains unchanged.
- Division by zero causes a fixed-point divide program exception.
- Any of the even-numbered general registers ( 0 thru 14) can be used as the operand 1 register pair.

\section*{Example:}
\begin{tabular}{|c|c|c|}
\hline LABEL & \multicolumn{2}{|l|}{\(\triangle\) OPERATIONA} \\
\hline 1 & 10 & 16 \\
\hline & SR & 6,6 \\
\hline & L & 7,DIVIDEND \\
\hline & D & 6,DIVISOR \\
\hline & - & \\
\hline & & \\
\hline DIVIDEND & DC & F'1685' \\
\hline DIVISOR & DC & \(\mathrm{F}^{\prime} \mathbf{2}^{\prime}\) \\
\hline
\end{tabular}

Registers 6 and 7 before execution of \(D\) instruction:


DIVISOR before and after execution of D instruction:
\begin{tabular}{|c|c|c|c|c|c|c|c|}
\hline 0000 & 0000 & 0000 & 0000 & 0000 & 0000 & 0000 & 0010 \\
\hline 0 & 0 & 0 & 0 & 0 & 0 & 0 & 2 \\
\hline
\end{tabular}

Registers 6 and 7 after execution of \(D\) instruction:


In this example, registers 6 and 7 are the operand 1 register pair and DIVISOR (operand 2) has been defined as a full word constant. First, the SR instruction clears register 6 to zeros. Since the full word in DIVIDEND can be contained in one register, it is loaded into register 7 (the odd-numbered register) through the use of the L instruction. Then, the register pair \(6-7\) is divided by the full word in DIVISOR. The resulting remainder occupies register 6 with a positive sign (the same as the dividend) and the resulting quotient occupies register 7 with a positive sign (determined algebraically).

Example:
\begin{tabular}{|c|c|c|}
\hline LABEL & \multicolumn{2}{|l|}{\(\triangle\) OPERATION \(\triangle\)} \\
\hline 1 & 10 & 16 \\
\hline & LM & 6,7,DIVIDEND \\
\hline & D & 6,DIVISOR \\
\hline & - & \\
\hline & & \\
\hline \multirow[t]{2}{*}{DIVIDEND} & DC & \(F^{\prime \prime} 1\) \\
\hline & DC & F'15' \\
\hline DIVISOR & DC & \(F^{\prime} 1 \varnothing \emptyset \emptyset^{\prime}\) \\
\hline
\end{tabular}

Registers 6 and 7 before execution of \(D\) instruction:


DIVISOR before and after execution of \(D\) instruction:


Registers 6 and 7 after execution of \(D\) instruction:


In this example, the even-odd register pair is loaded with the contents of DIVIDEND. This is done through the LM instruction because the dividend cannot be contained in one register and has a value of \(+4,294,967,311\) which is greater than
\[
\begin{aligned}
& +2,147,483,647\left(2^{31}-1\right) \\
& -2,147,483,648\left(-2^{31}\right) .
\end{aligned}
\]

The content of DIVISOR is then divided into the double-word value in the even-odd register pair. The resulting quotient with sign occupies the odd-numbered register and the resulting remainder with sign occupies the even-numbered register.

\subsection*{10.12. LOAD (L)}
\begin{tabular}{|c|c|c|c|}
\hline \multicolumn{4}{|c|}{ General } \\
\hline OPCODE & FORMAT & \begin{tabular}{l} 
OBJECT \\
INST. \\
TYPE
\end{tabular} & \begin{tabular}{l} 
LGTH. \\
(BYTES)
\end{tabular} \\
\hline MNEM. & HEX. & R & \(\mathbf{5 8}\)
\end{tabular} RX \(\quad 4\).
\begin{tabular}{|c|}
\hline Condition Codes \\
\hline\(\square\) IF RESULT \(=0\), SET TO O \\
IF RESULT \(<0\), SET TO 1 \\
IF RESULT \(>0\), SET TO 2 \\
IFOVERFLOW, SET TO 3 \\
UNCHANGED \\
\hline
\end{tabular}
\begin{tabular}{|c|c|}
\hline \multicolumn{2}{|r|}{Possible Program Exceptions} \\
\hline addressing & \(\square\) Protection \\
\hline \(\square\) DATA (INVALIDSIGN/DIGIT) & \(\square\) significance \\
\hline \(\square\) decimal divide & - SPECIFICATION: \\
\hline \(\square\) decimal overflow & \(\square\) NOT A FLOATING-POINT REGISTER \\
\hline \(\square\) ExECUTE & \(\square\) OP 1 NOT ON HALF-WORD BOUNDARY \\
\hline \(\square\) EXPONENT OVERFLOW & \(\square\) OP 2 NOT ON HALF WORD BOUNDARY \\
\hline \(\square\) EXPONENT UNDERFLOW & - OP 2 NOT ON FULL-WORD BOUNDAR \\
\hline \(\square\) FIXED-POINT DIVIDE & \(\square\) OP 2 NOT ON DOUBLEWORD \\
\hline \(\square\) FIXED-POINT OVERFLOW & \(\square\) BOUNDARY \\
\hline \(\square\) FLOATING-POINT DIVIDE & \begin{tabular}{l}
op 1 NOT EVEN NUMBERED REGISTER \\
OP 1 NOT ODD NUMBERED REGISTER
\end{tabular} \\
\hline \(\square\) OPERATION & \(\square\) NONE \\
\hline
\end{tabular}

The load \((L)\) instruction places the full-word in operand 2 into the operand 1 register.

\section*{Explicit Format:}
\begin{tabular}{r|l|l} 
LABEL & \(\triangle\) OPERATION \(\triangle\) & \\
\hline [symbol] & L & \(\mathrm{r}_{1}, \mathrm{~d}_{\mathbf{2}}\left(\mathrm{x}_{2}, \mathrm{~b}_{\mathbf{2}}\right)\)
\end{tabular}

Implicit Format:
\begin{tabular}{l|l|l} 
LABEL & \(\triangle\) OPERATION \(\triangle\) & \\
\hline [symbol] & L & \(\mathrm{r}_{1}, \mathrm{~s}_{2}\left(\mathrm{x}_{2}\right)\)
\end{tabular}

\section*{Operational Considerations:}
- Any of the general registers ( 0 through 15 ) can be used as operand 1.
- Operand 2 must be either defined as a full word or aligned on a full-word boundary.

Example:


Register 4 before execution of \(L\) instruction:
\begin{tabular}{|c|c|c|c|c|c|c|c|}
\hline 0000 & 0000 & 0000 & 0000 & 0010 & 1111 & 1001 & 1000 \\
\hline 0 & 0 & 0 & 0 & 2 & \(F\) & 9 & 8 \\
\hline
\end{tabular}
binary (leftover data from
hex previous program) hex previous program)

XNUM before and after execution of \(L\) instruction:


Register 4 after execution of \(L\) instruction:


In this example, XNUM is defined as a hexadecimal constant aligned on a full-word boundary and register 4 is the operand 1 register. The \(L\) instruction places the full word in operand 2 into register 4 replacing any leftover data in register 4 with the contents of XNUM.

\subsection*{10.13. LOAD (LR)}


The load (LR) instruction places the contents of the operand 2 register into the operand 1 register.

Explicit and Implicit Format:


\section*{Operational Considerations:}
- Any of the general registers ( 0 through 15 ) can be used as operands 1 and 2.
- The contents of the register specified by operand \(2\left(r_{2}\right)\) are loaded into the register specified by operand \(1\left(r_{1}\right)\).
- The contents of the register specified by operand \(2\left(r_{2}\right)\) remain unchanged.

Example:
\begin{tabular}{|c|c|c|c|}
\hline LABEL & \multicolumn{2}{|l|}{\(\triangle O P E R A T I O N \triangle\)} & OPERAND \\
\hline 1 & 10 & 16 & \\
\hline & \(L\) & 7,FINTOT & \\
\hline & L & 5, SUBTOT & \\
\hline & LR & 6,5 & \\
\hline & LR & 8,7 & \\
\hline & A & 5, INTERTOT & \\
\hline & AR & 7,5 & \\
\hline & CVD & 5, SUBTOTP & \\
\hline & CVD & 7,FINTOTP & \\
\hline & - & & \\
\hline & - & & \\
\hline FINTOT & DC & F'5630' & \\
\hline SUBTOT & DC & \(F^{\prime} 22{ }^{\prime \prime}\) & \\
\hline FINTOTP & DS & D & \\
\hline SUBTOTP & DS & D & \\
\hline INTERTOT & DC & \(F^{\prime} 2 \emptyset^{\prime}\) & \\
\hline
\end{tabular}

Register 6 before execution of LR instruction:
\begin{tabular}{|c|c|c|c|c|c|c|c|}
\hline 0000 & 0000 & 0000 & 0000 & 0000 & 0111 & 1100 & 1011 \\
\hline 0 & 0 & 0 & 0 & 0 & 7 & \(C\) & \(B\) \\
\hline
\end{tabular}
binary (leftover data from
hex previous program)

Register 5 before and after execution of LR instruction:


> binary
> hex

Register 6 after execution of LR instruction:
\begin{tabular}{|c|c|c|c|c|c|c|c|}
\hline 0000 & 0000 & 0000 & 0000 & 0000 & 0000 & 1101 & 1100 \\
\hline 0 & 0 & 0 & 0 & 0 & 0 & \(D\) & \(C\) \\
\hline
\end{tabular}

\section*{binary}
hex

In this example, the full word is FINTOT (FINTOT represents final total) is loaded into register 7 and the full word is SUBTOT (SUBTOT represents subtotal) is loaded into register 5. Then the content of register 5 is loaded into register 6 and the content of register 7 is loaded into register 8 so it can be saved prior to the execution of the suceeding add instructions. Then the full word in INTERTOT is added to register 5 (now register 5 has the most-current subtotal). The content of register 5 is added to the content of register 7 (now register 7 has the most current final total). The first CVD instruction converts the binary number in register 5 to its decimal equivalent and puts the result into the doubleword in SUBTOTP. The second CVD instruction converts the binary number in register 7 to its decimal equivalent and puts the result into the doubleword in FINTOTP.

\subsection*{10.14. LOAD AND TEST (LTR)}

\begin{tabular}{|c|c|}
\hline \multicolumn{2}{|r|}{Possible Program Exceptions} \\
\hline ADDRESSING
DATA (INVALID SIGN/DIGIT)
decimal divide
decimal overflow
EXECUTE
EXPONENT OVERFLOW
EXPONENT UNDERFLOW
FIXED-POINT DIVIDE
FIXED-POINT OVERFLOW
floAting-point divide
operation & \begin{tabular}{l}
PROTECTION -
SIGNIFICANCE
SPECIFICATION:
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 \\
OP 2 NOT ON DOUBLE-WORD \\
BOUNDARY \\
OP 1 NOT EVEN NUMBERED REGISTER \\
OP 1 NOT ODD NUMBERED REGISTER \\
NONE
\end{tabular} \\
\hline
\end{tabular}

The load and test (LTR) instruction places the contents of the operand 2 register into the operand 1 register. The value and sign of operand 2 determines the setting of the condition code. The actual testing of the condition code is done through the execution of another instruction.

Explicit and Implicit Format:
\begin{tabular}{l|l|l} 
LABEL & \(\triangle\) OPERATION \(\triangle\) & OPERAND \\
\hline [symbol] & LTR & \(r_{1}, r_{2}\)
\end{tabular}

If operand \(2=0\), set to 0 .
If operand \(2<0\), set to 1 .
If operand \(2>0\), set to 2 .
Usually, a conditional branch instruction tests the resulting condition code for an equal to zero, less than zero, or greater than zero condition. If the condition specified is met, a branch takes place accordingly. If not, the program continues processing with the following instruction.

\section*{Operational Considerations:}
- Any of the general registers ( 0 through 15 ) can be used as operands 1 and 2.
- It is your responsibility to test the condition code setting.

Example:
\begin{tabular}{|c|c|c|c|}
\hline \multirow[t]{2}{*}{\[
\frac{\text { LABEL }}{1}
\]} & \multicolumn{2}{|l|}{\(\triangle O P E R A T I O N \triangle\)} & \multirow[t]{2}{*}{OPERAND} \\
\hline & 10 & 16 & \\
\hline & L & 6,=F'25' & \\
\hline & LTR & 7,6 & \\
\hline & BC & 8,ERRTN & \\
\hline & - & & \\
\hline & - & & \\
\hline ERRTN & AP & ERCNT, =P'11 & \\
\hline & - & & \\
\hline & - & & \\
\hline ERCNT & DC & PL2' \(\square^{\prime}\) & \\
\hline
\end{tabular}

Register 7 before execution of LTR instruction:
\begin{tabular}{|c|c|c|c|c|c|c|c|}
\hline 0000 & 0000 & 0000 & 0000 & 1010 & 0000 & 0000 & 0000 \\
\hline 0 & 0 & 0 & 0 & \(A\) & 0 & 0 & 0 \\
\hline
\end{tabular}
binary (leftover data from
hex previous program)

Register 6 before and after execution of LTR instruction:
\begin{tabular}{|c|c|c|c|c|c|c|c|}
\hline 0000 & 0000 & 0000 & 0000 & 0000 & 0000 & 0001 & 1001 \\
\hline 0 & 0 & 0 & 0 & 0 & 0 & 1 & 9 \\
\hline
\end{tabular}

\section*{binary}
hex

Register 7 after execution of LTR instruction:


In this example, a full word containing the decimal value 25 is loaded into register 6. Then, the LTR instruction loads the contents of register 6 into register 7. The condition code is set to 2 , since the value of register 6 (operand 2 ) is greater than zero. The BC instruction tests for an equal to zero condition which is represented by the decimal value 8 in operand 1. If an equal to condition existed, a branch to the instruction labeled ERRTN would take place. Since that condition does not exist, the program continues processing with the instruction immediately following the BC instruction.
10.15. LOAD HALF WORD (LH)


The load half word (LH) instruction places the half word in operand 2 into the operand 1 register.

\section*{Explicit Format:}
\begin{tabular}{l|l|l} 
LABEL & \(\triangle\) OPERATION \(\triangle\) & \\
\hline [symbol] & LH & \(\mathrm{r}_{1}, \mathrm{~d}_{2}\left(\mathrm{x}_{2}, \mathrm{~b}_{2}\right)\)
\end{tabular}

Implicit Format:
\begin{tabular}{l|l|l} 
LABEL & \(\triangle\) OPERATION \(\Delta\) & OPERAND \\
\hline [symbol] & LH & \(r_{1}, s_{2}\left(x_{2}\right)\)
\end{tabular}

Since registers only work in conjunction with full words, the half word in operand 2 is automatically expanded to 32 bits by propagating the sign bit through the 16 high order bit positions. Then, operand 2 is loaded into the operand 1 register.

Operational Considerations:
- Any of the general registers (0 through 15) can be used as operand 1.
- Operand 2 must either be defined as a half word or aligned on a half-word boundary.

Example:
\begin{tabular}{lll} 
LABEL & \(\triangle O P E R A T I O N \Delta\) & OPERAND \\
1 & 10 & 16
\end{tabular}
\begin{tabular}{|c|c|c|}
\hline & LH & 4,PRODUCT \\
\hline & - & \\
\hline & . & \\
\hline PRODUCT & DC & H'256' \\
\hline
\end{tabular}

Register 4 before execution of LH instruction:

binary (leftover data from
hex previous program)

PRODUCT before and after execution of LH instruction:


Register 4 after execution of LH instruction:

binary
hex

In this example, the half word in PRODUCT is expanded temporarily to a 32 -bit signed integer. Then the LH instructions loads the contents of PRODUCT (now a 32-bit signed integer) into register 4.

\subsection*{10.16. LOAD MULTIPLE (LM)}
\begin{tabular}{|c|c|c|c|}
\hline \multicolumn{3}{|c|}{ General } \\
\hline OPCODE & FORMAT \\
\hline TYPE & \begin{tabular}{l} 
OBJECT \\
INST. \\
LGTH. \\
(BYTES)
\end{tabular} \\
\hline MNEM. & HEX.
\end{tabular}
\begin{tabular}{|c|c|}
\hline \multicolumn{2}{|r|}{Possible Program Exceptions} \\
\hline ADDRESSING
DATA (INVALIDSIGN/DIGIT)
DECIMAL DIVIDE
DECIMAL OVERFLOW
EXECUTE
EXPONENT OVERFLOW
EXPONENT UNDERFLOW
FIXED-POINT DIVIDE
FIXED-POINT OVERFLOW
FLOATING-POINT DIVIDE
operation & PROTECTION
SIGNIFICANCE
SPECIFICATION:
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 OP 2 NOT ON DOUBLE-WORD BOUNDARY OP 1 NOT EVEN NUMBERED REGISTER OP 1 NOT ODD NUMBERED REGISTER NONE \\
\hline
\end{tabular}

The load multiple (LM) instruction loads the contents of two or more consecutive registers (operands 1 and 3) with an equal number of consecutive full words in main storage (operand 2).

\section*{Explicit Format:}
\begin{tabular}{c|l|l} 
LABEL & \(\triangle\) OPERATION \(\triangle\) & \\
\hline [symbol] & LM & \(\mathrm{r}_{1}, \mathrm{r}_{3}, \mathrm{~d}_{2}\left(\mathrm{~b}_{2}\right)\)
\end{tabular}

Implicit Format:
\begin{tabular}{l|l|l} 
LABEL & \(\triangle\) OPERATION \(\triangle\) & \\
\hline [symbol] & LM & \(r_{1}, r_{3}, s_{2}\)
\end{tabular}

The operand 1 register is the first register loaded and the operand 3 register is the last register loaded. If operands 1 and 3 are not consecutive, any registers consecutive to the operand 1 register up to and including the operand 3 register also are included. If the address of the operand 3 register is less than the address of the operand 1 register, the register addresses wrap around from 15 to 0 . The number of full words in main storage to be loaded is determined by the number of consecutive registers specified. The registers are loaded in ascending sequence starting with the operand 1 register up to and including the operand 3 register. The content of operand 2 is loaded into the registers beginning with the byte addressed by the operand 2 label and continuing with as many full words that are needed to fill the registers specified.

\section*{Operational Considerations:}
- Any of the general registers ( 0 thru 15 ) can be used as operands 1 and 3 .
- Operand 2 must either be defined as a full word or aligned on a full-word boundary.
- If operand 2 does not reference the correct number of full words needed to fill all the registers, full words consecutive to the first full word specified by operand 2 are loaded into the registers until the operand 3 register is filled.
- When loading multiple registers, the wrap-around concept applies.
- If operand 1 and operand 3 reference the same register, only that register is loaded with the contents of the first full word of operand 2.

\section*{Example:}
\begin{tabular}{lll} 
LABEL & \(\triangle O P E R A T I O N \Delta\) & OPERAND
\end{tabular}
\begin{tabular}{lll} 
& LM & 5,7, VALI \\
& \(\cdot\) & \\
& \(\cdot\) & \\
VALI & \(\dot{D C}\) & \(F^{\prime} 1 \emptyset^{\prime}\) \\
VAL2 & DC & \(F^{\prime} \emptyset^{\prime}\) \\
VAL3 & DC & \(F^{\prime} 3 \emptyset^{\prime}\)
\end{tabular}

Registers 5, 6, and 7 before execution of LM instruction:


Register 7

leftover data from previous program

VAL1, VAL2, and VAL3 before and after execution of LM instruction:


Registers 5, 6, and 7 after execution of LM instruction:

Register 5


Register 6


Register 7


In this example, operands 1 and 3 specify that registers 5,6 , and 7 are to be loaded with three consecutive full words from main storage starting with the first full word at VAL1 (operand 2 ) and continuing until register 7 is filled.

Example:


Register 5 before execution of LM instruction:
\begin{tabular}{|c|c|c|c|c|c|c|c|}
\hline 0000 & 0000 & 0000 & 0000 & 0000 & 0000 & 0000 & 0000 \\
\hline 0 & 0 & 0 & 0 & 0 & 0 & 0 & 0 \\
\hline
\end{tabular}

\section*{binary}
hex

TAG1, TAG2, TAG3 before and after execution of LM instruction:


Register 5 after execution of LM instruction:

binary
hex

In this example, operand 1 and operand 3 both refer to register 5 . Therefore, the content of operand 2 is loaded into register 5 (operand 1) beginning with the first byte at TAG1 and continuing with as many full words that are needed to fill register 5 (operand 3). Note that only register 5 is filled with the first full word at operand 2.

\section*{Example:}


Registers before execution of LM instruction:

operand 1


Register 2


SECTOR before and after execution of LM instruction:

\begin{tabular}{|c|c|c|c|c|c|c|c|c|}
\hline 000010000 & 0000,0000 & 0000 & 1000 & 111111100 & 000010000 & 0000,0000 & 0000,0011 & 1110/1000 \\
\hline 010 & 010 & 01 & 18 & Fic & 0 1 0 & 0110 & 013 & E 18 \\
\hline
\end{tabular}
\begin{tabular}{|c|c|c|c|c|c|c|c|}
\hline 0000 & 0000 & 0000 & 0000 & 0001 & 1000 & 0011 & 1000 \\
\hline 0 & 0 & 0 & 0 & 1 & 8 & 3 & 8 \\
\hline
\end{tabular}

\footnotetext{
binary
hex
}

Registers after execution of LM instruction:


In this example, register 14 is the first register loaded and register 2 is the last register loaded. Since the address of operand 2, (register 2 ) is less than the address of operand 1 (register 14), the register addresses wrap around from 15 to 0 up to and including 2. Operand 2 is either defined as a full word or aligned on a full-word boundary. The contents of operand 2 is loaded into register 14 starting with the byte addressed by SECTOR and continuing with as many full words until register 2 is filled.

Remember that most \(1 / O\) operations use registers \(14,15,0\), and 1 . So, if you use these registers and then perform some input or output in your program, the original contents of these registers are destroyed. However, you can use these registers if you save the contents prior to every 1/O operation, and restore them after completing each 1/O operation.

It may be helpful to note that the Supervisor usually uses the lower numbered registers and Data Management usually uses the higher numbered registers.
10.17. MULTIPLY (M)


The multiply \((\mathrm{M})\) instruction algebraically multiplies the operand 1 register pair by the full word in operand 2. The result replaces the operand 1 register pair.

\section*{Explicit Format:}
\begin{tabular}{l|l|l} 
LABEL & \(\triangle\) OPERATION \(\triangle\) & \\
\hline [symbol] & \(M\) & \(r_{1}, d_{2}\left(x_{2}, b_{2}\right)\)
\end{tabular}

Implicit Format:
\begin{tabular}{l|l|l} 
LabeL & \(\triangle\) OPERATION \(\Delta\) & \\
\hline OPymbol] & \(M\) & \(r_{1}, s_{2}\left(x_{2}\right)\)
\end{tabular}

Operand 1 must be a contiguous pair of even-odd registers. The even-numbered register, since it is lower numbered register, is specified as operand 1. Both the multiplier (operand 2) and the multiplicand (operand 1) are 32-bit signed integers but the product is always a 64 -bit signed integer. Before execution of the \(M\) instruction, the multiplicand must be loaded into the odd-numbered register, while the content of the even-numbered register is ignored. The multiplier must either be defined as a full word or aligned on a full-word boundary. After execution of the \(M\) instruction, the resulting product replaces the evenodd register pair as a double-word value with the high order bits or bit as the sign value. The sign of the product is determined algebraically; like signs produce positive results and unlike signs produce negative results. If the product is always contained in the oddnumbered register, you can ignore the contents of the even-numbered register and store the contents of the odd-numbered register as the product.

\section*{Operational Considerations:}
- Operand 1 consists of an even-odd pair of registers located in consecutive order in the processor.
- Operand 1 always references the even-numbered register.
- The multiplicand occupies the odd-numbered register as a full-word value.
- After the \(M\) instruction is executed, the product occupies both registers as a doubleword value.
- Operand 2 must either be defined as a full word or aligned on a full-word boundary.
- Any of the even-numbered general registers ( 0 thru 14 ) can be used as operand 1.

\section*{Example:}


Registers 4 and 5 before execution of \(M\) instruction:


MULTPLYR before and after execution of \(M\) instruction:

binary
hex

Registers 4 and 5 after execution of \(M\) instruction:


In this example, the full-word value in MULTCAND is loaded into register 5 (odd-numbered register). Then, the full-word value in MULTPLYR is multiplied by register 4 (the even-odd register pair). The even-numbered register is ignored and the content of the odd-numbered register (in this case, 5) is used in the multiplication.

The resulting product replaces the even-odd register pair as a double-word value. Since the value of this product is less than \(+2,147,483,647\), it can be contained in register 5 and register 4 can be ignored.

Example:
\begin{tabular}{lll} 
LABEL & OOPERATION \(\Delta\) \\
1 & 10 & 16
\end{tabular}

OPERAND
\begin{tabular}{cc} 
L & 7,MULTCAND \\
M & 6, MULTPLYR \\
ST & 7, HOLDAREA \\
\(\cdot\) & \\
• & \\
MULTCAND DC & \(F^{\prime} 35 \emptyset^{\prime}\) \\
MULTPLYR DC & \(F^{\prime}-5^{\prime}\) \\
HOLDAREA DS & \(F\)
\end{tabular}

Registers 6 and 7 before execution of \(M\) instruction:


MULTPLYR before and after execution of \(M\) instruction:


Registers 6 and 7 after execution of \(M\) instruction:

binary
hex
(-1750 in twos complement form)
10.18. STORE (ST)


The store (ST) instruction places the contents of the operand 1 register unchanged into the full word in operand 2.

\section*{Explicit Format:}
\begin{tabular}{l|l|l} 
LABEL & \(\triangle\) OPERATION \(\triangle\) & \\
\hline [symbol] & ST & \(\mathrm{r}_{1}, \mathrm{~d}_{2}\left(\mathrm{x}_{2}, \mathrm{~b}_{2}\right)\)
\end{tabular}

Implicit Format:
\begin{tabular}{c|l|l} 
LABEL & \(\triangle\) OPERATION \(\triangle\) & \\
\hline [symbol] & ST & \(\mathrm{r}_{1}, \mathrm{~s}_{\mathbf{2}}\left(\mathrm{x}_{2}\right)\)
\end{tabular}

\section*{Operational Considerations:}
- Any of the general registers ( 0 through 15 ) can be used as operand 1.
- Operand 2 must either be defined as a full word or aligned on a full-word boundary.
- Unlike most instructions, the ST instruction has operand 1 as the sending field and operand 2 as the receiving field.

Example:
\begin{tabular}{|c|c|c|c|}
\hline LABEL & \multicolumn{2}{|l|}{\(\triangle O P E R A T I O N \triangle\)} & \multirow[t]{2}{*}{OPERAND} \\
\hline 1 & 10 & 16 & \\
\hline & L & 7, \(=\mathrm{F}^{\prime} 25^{\prime}\) & \\
\hline & - & & \\
\hline & - & & \\
\hline & ST & 7, CHART+4 & \\
\hline & - & & \\
\hline & - & & \\
\hline CHART & DC & \(\mathrm{F}^{\prime} 22^{\prime}\) & \\
\hline & DC & \(\mathrm{F}^{\prime} 5 \chi^{\prime}\) & \\
\hline & DC & \(\mathrm{F}^{\prime} 28{ }^{\prime}\) & \\
\hline
\end{tabular}

CHART +4 before execution of ST instruction:


Register 7 before and after execution of ST instruction:
\begin{tabular}{|c|c|c|c|c|c|c|c|}
\hline \(0000 ; 0000\) & 0000 & 0000 & 0000 & 0000 & 0001 & 1001 \\
\hline 0 & 0 & 0 & 0 & 0 & 0 & 1 & 9 \\
\hline
\end{tabular}\(\quad\)\begin{tabular}{l} 
binary \\
\hline
\end{tabular}

CHART+4 after execution of ST instruction:


In this example, register 7 is loaded with a full-word value of 25 . Then the content of register 7 destroys the content of the second full word in CHART and replaces it with the content of register 7 .

\subsection*{10.19. STORE HALF WORD (STH)}
\begin{tabular}{|c|c|c|c|c|c|c|}
\hline \multicolumn{4}{|c|}{General} & \multicolumn{3}{|r|}{Possible Program Exceptions} \\
\hline \multicolumn{2}{|l|}{OPCODE} & \multirow[t]{2}{*}{FORMAT TYPE} & \multirow[t]{2}{*}{\begin{tabular}{l}
OBJECT \\
INST. \\
LGTH. \\
(BYTES)
\end{tabular}} & \multirow[t]{5}{*}{ADDRESSING
DATA (INVALIDSIGN/DIGIT)
DECIMAL DIVIDE
DECIMAL OVERFLOW
EXECUTE
EXPONENT OVERFLOW
EXPONENT UNDERFLOW
FIXED-POINT DIVIDE
FIXED-POINT OVERFLOW
FLOATING-POINT DIVIDE
OPERATION} & \multicolumn{2}{|l|}{\multirow[t]{5}{*}{\begin{tabular}{l}
PROTECTION \\
SIGNIFICANCE \\
SPECIFICATION: \\
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 \\
OP 2 NOT ON DOUBLE-WORD \\
BOUNDARY \\
OP 1 NOT EVEN NUMBERED REGISTER \\
OP 1 NOT ODD NUMBERED REGISTER \\
NONE
\end{tabular}}} \\
\hline MNEM. & HEX. & & & & & \\
\hline STH & 40 & RX & 4 & & & \\
\hline \multicolumn{4}{|c|}{Condition Codes} & & & \\
\hline \multicolumn{4}{|l|}{IF RESULT \(=0\), SET TO O if RESULT<0, SET TO 1 IF RESULT \(>0\) O, SET TO 2 IF OVERFLOW, SET TO 3 UNCHANGED} & & & \\
\hline
\end{tabular}

The store half word (STH) instruction places bits 16 through 31 of the operand 1 register unchanged into the half word in operand 2.

\section*{Explicit Format:}
\begin{tabular}{l|l|l} 
LABEL & \(\triangle\) OPERATION \(\triangle\) & \\
\hline [symbol] & STH & \(\mathrm{r}_{1}, \mathrm{~d}_{2}\left(\mathrm{x}_{2}, \mathrm{~b}_{2}\right)\)
\end{tabular}

Implicit Format:
\begin{tabular}{l|l|l} 
LABEL & \(\triangle\) OPERATION \(\triangle\) & \\
\hline [symbol] & STH & \(\mathrm{r}_{1}, \mathrm{~s}_{\mathbf{2}}\left(\mathrm{x}_{\mathbf{2}}\right)\)
\end{tabular}

Operational Considerations:
- Any of the general registers ( 0 through 15 ) can be used as operand 1.
- Operand 2 must be either defined as a half word or aligned on a half-word boundary.
- Unlike most instructions, the STH instruction has operand 1 as the sending field and operand 2 as the receiving field.

\section*{Example:}
\begin{tabular}{|c|c|c|c|}
\hline LABEL & \multicolumn{2}{|l|}{\(\triangle\) OPERATIONA} & OPERAND \\
\hline 1 & 10 & 16 & \\
\hline & LA & 7, HALFBUF & \\
\hline & LH & 6, = \({ }^{\prime}\) '43' & \\
\hline & CH & 6,CONSTANT & \\
\hline & BNE & ERROR & \\
\hline & - & & \\
\hline & \(\cdot\) & & \\
\hline ERROR & STH & 6,ø(7) & \\
\hline & A & \(7,=\mathrm{F}^{\prime} \mathbf{2}^{\prime}\) & \\
\hline & - & & \\
\hline & - & & \\
\hline CONSTANT & DC & H'50' & \\
\hline & DS & 0 H & \\
\hline HALFBUF & DS & CL8ø & \\
\hline
\end{tabular}

HALFBUF (2) before execution of STH instruction:


Register 6 before and after execution of STH instruction:


\section*{binary}
hex

HALFBUF (2) after execution of STH instruction:


In this example, the address of HALFBUF is loaded into register 7, and the half-word decimal value of 43 is loaded into register 6 . Then, the content of register 6 is compared to the half-word decimal value in CONSTANT. Since the value 43 is less than 50, the condition code is set to 1 and the branch to the instruction labeled ERROR takes place. There, bits 16 through 31 of register 6 are stored in the first two bytes of HALFBUF. A full word of 2 is then added to the address in register 7 which increases the address by 2 bytes. This makes it possible for the next unequal condition to be stored in the succeeding two bytes and so on.

\subsection*{10.20. STORE MULTIPLE (STM)}
\begin{tabular}{|c|c|c|c|c|c|}
\hline \multicolumn{4}{|c|}{General} & \multicolumn{2}{|r|}{Possible Program Exceptions} \\
\hline \multicolumn{2}{|l|}{OPCODE} & \multirow[t]{2}{*}{FORMAT TYPE} & \multirow[t]{2}{*}{\begin{tabular}{l}
OBJECT \\
inst. \\
LGTH. \\
(BYTES)
\end{tabular}} & \multirow[t]{5}{*}{ADDRESSING
DATA (INVALIDSIGN/DIGIT)
DECIMAL DIVIDE
DECIMAL OVERFLOW
EXECUTE
EXPONENT OVERFLOW
EXPONENT UNDERFLOW
FIXED-POINT DIVIDE
FIXED-POINT OVERFLOW
FLOATING.POINT DIVIDE
OPERATION} & \multirow[t]{5}{*}{\begin{tabular}{l}
PROTECTION
SIGNIFICANCE
SPECIFICATION:
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 \\
OP 2 NOT ON DOUBLE-WORD \\
BOUNDARY \\
OP 1 NOT EVEN NUMBERED REGISTER \\
OP 1 NOT ODD NUMBERED REGISTER
NONE
\end{tabular}} \\
\hline MNEM. & HEX. & & & & \\
\hline STM & 90 & RS & 4 & & \\
\hline \multicolumn{4}{|c|}{Condition Codes} & & \\
\hline \multicolumn{4}{|l|}{IF RESULT \(=0\), SET TO O
IF RESULT < O, SET TO 1
IF RESULT \(>0\), SET TO 2
IF OVERFLOW, SET TO 3 UNCHANGED} & & \\
\hline
\end{tabular}

The store multiple (STM) instruction places the contents of two or more consecutive registers (operands 1 and 3 ) into an equal number of consecutive full words in main storage (operand 2).

\section*{Explicit Format:}
\begin{tabular}{c|l|l} 
LABEL & \(\triangle\) OPERATION \(\triangle\) & \\
\hline [symbol] & STM & \(r_{1}, r_{3}, d_{2}\left(b_{2}\right)\)
\end{tabular}

\section*{Implicit Format:}
\begin{tabular}{l|l|l} 
LABEL & DOPERATION \(\triangle\) & \\
\hline [symbol] & STM & \(r_{1}, r_{3}, s_{2}\)
\end{tabular}

The operand 1 register is the first register stored and the operand 3 register is the last register stored. If operands 1 and 3 are not consecutive, any registers consecutive to the operand 1 register up to and including the operand 3 register are also included. If the address of the operand 3 register is less than the address of the operand 1 register, the register addresses wrap around from 15 to 0 . The contents of the registers are stored in ascending sequence into an equal number of consecutive full words in main storage starting with the byte addressed by the operand 2 label, and continuing with as many full words that are needed to receive the contents of the registers specified.

\section*{Operational Considerations:}
- Any of the general registers (0 through 15 ) can be used as operand 1 and operand 3.
- Operand 2 must be defined as a full word or aligned on a full-word boundary.
- If operand 2 does not reference the correct number of full words needed to receive the contents of all the registers specified, full words consecutive to the first full word specified by operand 2 are filled until the contents of the operand 3 register has been stored.
- When storing multiple registers, the wraparound concept applies.
- If operand 1 and operand 3 reference the same register, only the contents of that register is stored in the first full word of operand 2.

\section*{Example:}
\begin{tabular}{|c|c|c|c|}
\hline LABEL \(\triangle\) & \multicolumn{2}{|l|}{\(\triangle\) OPERATIONA} & OPERAND \\
\hline 1 & 10 & 16 & \\
\hline & ZAP & DWORD, \(=\) P'525 \({ }^{\prime}\) & \\
\hline & CVB & 5, DWORD & \\
\hline & M & 4 ,MULTPLYR & \\
\hline & STM & 4,5,DWORD & \\
\hline & - & & \\
\hline & - & & \\
\hline DWORD & DS & D & \\
\hline MULTPLYR & DC & \(F^{\prime} 26^{\prime}\) & \\
\hline
\end{tabular}

DWORD before execution of STM instruction:


Registers 4 and 5 before and after execution of STM instruction:


DWORD after execution of STM instruction:

binary hex

In this example, the packed decimal number 525 is added to DWORD, which was previously cleared to zero. Then, the double word in DWORD is converted into its binary equivalent and the result is placed in register 5 . The contents of registers 4 and 5 are then multiplied by the full word in MULTPLYR and the result replaces registers 4 and 5 as a double-word value. Register 4 (operand 1) and register 5 (operand 3) are stored in the first two full words in DWORD.

\section*{S}

\subsection*{10.21. SUBTRACT (S)}
\begin{tabular}{|c|c|c|c|c|c|c|c|}
\hline \multicolumn{4}{|c|}{General} & \multicolumn{4}{|r|}{Possible Program Exceptions} \\
\hline \multicolumn{2}{|l|}{OPCODE} & \multirow[t]{2}{*}{FORMAT TYPE} & \multirow[t]{2}{*}{\begin{tabular}{l}
OBJECT \\
INST. \\
LGTH. \\
(BYTES)
\end{tabular}} & \multirow[t]{9}{*}{ADDRESSING
DATA (INVALIDSIGN/DIGIT)
DECIMAL DIVIDE
DECIMAL OVERFLOW
EXECUTE
EXPONENT OVERFLOW
EXPONENT UNDERFLOW
FIXED-POINT DIVIDE
FIXED-POINT OVERFLOW
FLOATING-POINT DIVIDE
OPERATION} & \multicolumn{3}{|l|}{\multirow[t]{9}{*}{\begin{tabular}{l}
PROTECTION \\
SIGNIFICANCE \\
SPECIFICATION: \\
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 \\
OP 2 NOT ON DOUBLE-WORD \\
BOUNDARY \\
OP 1 NOT EVEN NUMBERED REGISTER \\
OP 1 NOT ODD NUMBERED REGISTER \\
NONE
\end{tabular}}} \\
\hline MNEM. & HEX. & & & & & & \\
\hline S & 5B & RX & 4 & & & & \\
\hline \multicolumn{4}{|c|}{\multirow[b]{2}{*}{Condition Codes}} & & & & \\
\hline & & & & & & & \\
\hline \multicolumn{4}{|l|}{\multirow[t]{4}{*}{IF RESULT \(=0\), SET TO O if RESULT<0, SET TO 1 IF RESULT>0, SET TO 2 IF OVERFLOW, SET TO 3 UNCHANGED}} & & & & \\
\hline & & & & & & & \\
\hline & & & & & & & \\
\hline & & & & & & & \\
\hline
\end{tabular}

The subtract ( S ) instruction subtracts the contents of the full word in operand 2 from the contents of the operand 1 register. The difference replaces the operand 1 register.

\section*{Explicit Format:}
\begin{tabular}{l|l|l} 
LABEL & \(\triangle\) OPERATION \(\Delta\) & \\
\hline [symbol] & \(S\) & \(r_{1}, d_{2}\left(x_{2}, b_{2}\right)\)
\end{tabular}

\section*{Implicit Format:}
\begin{tabular}{c|l|l} 
LABEL & \(\triangle\) OPERATION \(\triangle\) & \\
\hline [symbol] & S & \(\mathrm{r}_{1}, \mathbf{s}_{2}\left(\mathrm{x}_{2}\right)\)
\end{tabular}

When the actual subtraction takes place, the twos complement form of operand 2 is added to operand 1 . The sign of the result is determined algebraically.

Operational Considerations:
- Any of the general registers ( 0 through 15 ) can be used as operand 1.
- Operand 2 must be either defined as a full word or aligned on a full-word boundary.

\section*{Example:}
\begin{tabular}{|c|c|c|c|}
\hline \multirow[t]{2}{*}{LABEL
\[
1
\]} & \multicolumn{2}{|l|}{\(\triangle O P E R A T I O N \triangle\)} & \multirow[t]{2}{*}{OPERAND} \\
\hline & 10 & 16 & \\
\hline & L & 5, =F'52' & \\
\hline & S & 5,VALUE & \\
\hline & - & & \\
\hline VALUE & DC & F'll' & \\
\hline
\end{tabular}

Register 5 before execution of S instruction:
\begin{tabular}{|c|c|c:c|c|c|c|c|}
\hline 0000 & 0000 & 0000 & 0000 & 0000 & 0000 & 0011 & 0100 \\
\hline 0 & 0 & 0 & 0 & 0 & 0 & 3 & 4 \\
\hline
\end{tabular}
binary
hex

VALUE before and after execution of \(S\) instruction:


Register 5 after execution of \(S\) instruction:

binary
hex

\section*{SR}

\subsection*{10.22. SUBTRACT (SR)}
\begin{tabular}{|c|c|c|c|c|c|c|}
\hline \multicolumn{4}{|c|}{General} & \multicolumn{3}{|r|}{Possible Program Exceptions} \\
\hline \multicolumn{2}{|l|}{OPCODE} & \multirow[t]{2}{*}{FORMAT TYPE} & \multirow[t]{2}{*}{OBJECT inST. LGTH. (BYTES)} & \multirow[t]{9}{*}{ADDRESSING
DATA (INVALID SIGN/DIGIT)
DECIMAL DIVIDE
DECIMAL OVERFLOW
EXECUTE
EXPONENT OVERFLOW
EXPONENT UNDERFLOW
FIXED-POINT DIVIDE
FIXED-POINT OVERFLOW
FLOATING-POINT DIVIDE
OPERATION} & \multicolumn{2}{|l|}{\multirow[t]{9}{*}{\begin{tabular}{l}
PROTECTION
SIGNIFICANCE
SPECIFICATION:
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 \\
OP 2 NOT ON DOUBLE-WORD \\
BOUNDARY \\
OP 1 NOT EVEN NUMBERED REGISTER \\
OP 1 NOT ODD NUMBERED REGISTER \\
NONE
\end{tabular}}} \\
\hline MNEM. & HEX. & & & & & \\
\hline SR & 1 B & RR & 2 & & & \\
\hline \multicolumn{4}{|c|}{\multirow[b]{2}{*}{Condition Codes}} & & & \\
\hline & & & & & & \\
\hline \multicolumn{4}{|l|}{\multirow[t]{4}{*}{IF RESULT \(=0\), SET TO 0 IF RESULT < O, SET TO 1 IF RESULT \(>0\) O, SET TO 2 IF OVERFLOW, SET TO 3 UNCHANGED}} & & & \\
\hline & & & & & & \\
\hline & & & & & & \\
\hline & & & & & & \\
\hline
\end{tabular}

The subtract (SR) instruction subtracts the contents of the operand 2 register from the contents of the operand 1 register and places the difference in the operand 1 register.

Explicit and Implicit Format:
\begin{tabular}{c|l|l} 
LABEL & \(\triangle\) OPERATION \(\Delta\) & \\
\hline [symbol] & SR & \(r_{1}, r_{2}\)
\end{tabular}

When the actual subtraction takes place, the twos complement form of operand 2 is added to operand 1 . The sign of the result is determined algebraically.

\section*{Operational Considerations:}
- Any of the general registers can be used as operands 1 and 2.
- This instruction can be used to clear a register by subtracting the content of the register from itself.
- The subtraction is performed by converting the number in operand \(2\left(r_{2}\right)\) into a signed twos complement binary number and then algebraically adding it to the value in operand \(1\left(r_{1}\right)\).
- The maximum fixed-point number that can be contained in a 32-bit register is \(2,147,483,647\left(2^{31}-1\right)\); the minimum number is \(-2,147,483,648\left(-2^{31}\right)\). For decimal numbers outside this range, an overflow condition is produced.
- The contents of operand \(2\left(r_{2}\right)\) are not changed by the subtract (SR) instruction.

\section*{Example:}
\begin{tabular}{|c|c|c|c|}
\hline LABEL & \multicolumn{2}{|l|}{\(\triangle\) PPERATIONS} & OPERAND \\
\hline 1 & 10 & 16 & \\
\hline & LM & 5,6,HRS & \\
\hline & SR & 4,4 & \\
\hline & A & 5,HRSOT & \\
\hline & M & 4,RATE & \\
\hline & SR & 5,6 & \\
\hline & ST & 5,FLWRD & \\
\hline & - & & \\
\hline & & & \\
\hline HRS & DC & F'4ø' & \\
\hline deduc & DC & \(F^{\prime} 29161\) & \\
\hline HRSOT & DC & \(\mathrm{F}^{\prime}{ }^{\prime}\) & \\
\hline RATE & DC & F'350' & \\
\hline FLWRD & DS & F & \\
\hline
\end{tabular}

Register 4 after execution of first SR instruction:


Registers 4 and 5 before execution of second SR instruction:
\begin{tabular}{|c|c|c|c|c|c|c|c|c|c|c|c|c|c|c|c|}
\hline 0000 & 0000 & 0000 & & 0000 & 0000 & 0000 & 0000 & 0000 & 0000 & 0000 & 0000 & 0011 & 1010 & 1100 & 1010 \\
\hline 0 & 0 & 0 & 0 & 0 & 0 & 0 & 0 & 0 & 0 & 0 & 0 & 3 & A & c & A \\
\hline
\end{tabular}
binary hex

Register 6 before and after execution of SR instruction:


Registers 4 and 5 after execution of second SR instruction:


In this example, two full words (starting with the byte addressed by HRS and including the full word in DEDUC) are loaded into registers 5 and 6. The SR instruction clears register 4 to zeros and the content of HRSOT is added to the content of register 5. Register 5 now contains the standard 40 working hours per week plus any overtime hours. The content of RATE is multiplied by the even-odd register pair. The product replaces registers 4 and 5 as a double-word value. The content of register 6 is subtracted from register 5 (since the product is contained in one register) and the difference replaces register 5. Register 5 now contains one employee's weekly net pay. The content of register 5 is then stored in FLWRD in main storage.

\section*{SH}

\subsection*{10.23. SUBTRACT HALF WORD (SH)}
\begin{tabular}{|c|c|c|c|}
\hline \multicolumn{4}{|c|}{ General } \\
\hline OPCODE & FORMAT & \begin{tabular}{l} 
OBJECT \\
INST. \\
TYPE
\end{tabular} \\
\begin{tabular}{c|c|c|}
\hline LGTH. \\
(BYTES)
\end{tabular} \\
\hline MNEM. & HEX. & & RH \\
\hline 4B & RX & 4 \\
\hline
\end{tabular}
\begin{tabular}{|l|l|l|}
\hline \multicolumn{2}{|c|}{ Possible Program Exceptions } \\
\hline\(\square\) ADDRESSING & \(\square\) PROTECTION \\
\(\square\) DATA (INVALIDSIGN/DIGIT) & \(\square\) SIGNIFICANCE \\
\(\square\) DECIMAL DIVIDE & \(\square\) & SPECIFICATION: \\
\(\square\) DECIMAL OVERFLOW & \(\square\) & NOT A FLOATING-POINT REGISTER \\
\(\square\) EXECUTE & \(\square\) & OP 1 NOT ON HALFWORD BOUNDARY \\
\(\square\) EXPONENT OVERFLOW & \(\square\) & OP 2 NOT ON HALFWORD BOUNDARY \\
\(\square\) EXPONENT UNDERFLOW & \(\square\) & OP 2 NOT ON FULL-WORD BOUNDARY \\
\(\square\) FIXED-POINT DIVIDE & \(\square\) & OP 2 NOT ON DOUBLE-WORD \\
\(\square\) FIXEDPOINT OVERFLOW & \(\square\) & BOUNDARY \\
\(\square\) FLOATING-POINT DIVIDE & \(\square\) & OP 1 NOT EVEN NUMBERED REGISTER \\
\(\square\) OPERATION & \(\square\) & OP 1 NOT ODD NUMBERED REGISTER \\
& \(\square\) NONE \\
\hline
\end{tabular}

The subtract half word \((\mathrm{SH})\) instruction subtracts the contents of the half word in operand 2 from the contents of the operand 1 register. The difference replaces the operand 1 register.

\section*{Explicit Format:}
\begin{tabular}{l|l|l} 
LABEL & DOPERATION \(\triangle\) & \\
\hline [symbol] & SH & \(\mathbf{r}_{1}, \mathrm{~d}_{2}\left(\mathrm{x}_{2}, \mathrm{~b}_{2}\right)\)
\end{tabular}

Implicit Format:
\begin{tabular}{l|l|l} 
LABEL & \(\triangle\) OPERATION \(\triangle\) & \\
\hline [symbol] & SH & \(r_{1}, s_{2}\left(x_{2}\right)\)
\end{tabular}

Operand 2 is two bytes in length (a 16 -bit signed integer) and is located in main storage. Before operand 2 is subtracted from operand 1, operand 2 is temporarily expanded to 32 bits by propagating the sign bit through the high order 16 bit positions. Then the twos complement of operand 2 is added to operand 1 . The difference replaces the content of the operand 1 register.

Operational Considerations:
- Any of the general registers (0 through 15) can be used as operand 1.
- Operand 2 must either be defined as a half word or aligned on a half-word boundary.
- A fixed-point overflow condition can occur.
- Execution of the SH instruction sets the condition code accordingly.

\section*{Example:}
\begin{tabular}{|c|c|c|c|}
\hline LABEL & \(\triangle\) OPE & & OPERAND \\
\hline 1 & 10 & 16 & \\
\hline & LA & 5,2 & \\
\hline & L & 9,BADACTS & \\
\hline & CH & 5,CODECD & \\
\hline & BE & GDACTS & \\
\hline & - & & \\
\hline & \(\cdot\) & & \\
\hline GDACTS & SH & 9, VALUEI & \\
\hline & ST & 9,YTDACTS & \\
\hline & - & & \\
\hline & - & & \\
\hline CODECD & DC & \(H^{\prime} \mathbf{2 '}^{\prime}\) & \\
\hline BADACTS & DC & \(\mathrm{F}^{\prime}{ }^{\prime}\) & \\
\hline VALUEI & DC & H'1] & \\
\hline YTDACTS & DS & F & \\
\hline
\end{tabular}

Register 9 before execution of SH instruction:
\begin{tabular}{|c|c|c|c|c|c|c|c|c|}
\hline 0000 & 0000 & 0000 & 0000 & 0000 & 0000 & 0000 & 10011 \\
\hline 0 & 0 & 0 & 0 & 0 & 0 & 0 & 3 \\
\hline
\end{tabular}
binary
hex

VALUE1 before and after execution of SH instruction:


\footnotetext{
binary
hex
}

Register 9 after execution of SH instruction:

binary
hex

In this example, the decimal value 2 is loaded into register 5 and the content of BADACTS is loaded into register 9 . Then the content of register 5 is compared to the half-word value of CODECD. Since an equal to condition exists, the condition code is set to 0 . As a result, the following branch to the instruction labeled GDACTS takes place. There, the half word in VALUE1 is expanded to a 32 -bit signed integer, and the twos complement form of VALUE1 is added to register 9 . The difference occupies register 9 as a full-word value. Finally, the ST instruction stores the contents of register 9 in YTDACTS located in main storage.
-

\title{
11. Floating-Point Instructions
}

\subsection*{11.1. INTRODUCTION}

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 multiple (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 floatingpoint 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 of 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, subtractunnormalized, compare, halve, and multiply. In the execution of add-normalized, subtractnormalized, 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 most significant bit position of the guard digit. In the long format multiply instruction, 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 most significant bit position of the guard digit. In the long format multiply instruction, the guard digit is carried 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.

This section describes the operation of each floating-point instruction. The instructions are arranged in alphabetical order according to mnemonic operation code. Each description includes a list of the possible program exceptions and condition codes which may result. (See 2.1, 2.3, 2.6, 5.1, 5.2.12, Appendix C, and Appendix D.)

\subsection*{11.2. ADD NORMALIZED, LONG FORMAT (AD)}
\begin{tabular}{|c|c|c|c|}
\hline \multicolumn{4}{|c|}{ General } \\
\hline OPCODE & FORMAT & \begin{tabular}{l} 
OBJECT \\
TYPE \\
TNST. \\
LGTH. \\
(BYTES)
\end{tabular} \\
\hline MNEM. & HEX. & & \(\mathbf{4}\) \\
\hline AD & 6A & RX & 4 \\
\hline
\end{tabular}
Condition Codes
\(\square\) IF RESULT \(=0\), SET TO 0
IF RESULT \(<0\), SET TO 1
IF RESULT \(>0\), SET TO 2
\(\square\) IF OVERFLOW, SET TO 3
\(\square\) UNCHANGED
\begin{tabular}{|c|c|}
\hline \multicolumn{2}{|r|}{Possible Program Exceptions} \\
\hline ADDRESSING & - PROTECTION \\
\hline \(\square\) DATA (INVALID SIGN/DIGIT) & SIGNIFICANCE \\
\hline \(\square\) DECIMAL DIVIDE & \(\square\) SPECIFICATION: \\
\hline \(\square\) DECIMAL OVERFLOW & NOT A FLOATING-POINT REGISTER \\
\hline \(\square\) EXECUTE & \(\square\) OP 1 NOT ON HALF-WORD BOUNDARY \\
\hline EXPONENT OVERFLOW & \(\square\) OP 2 NOT ON HALF-WORD BOUNDARY \\
\hline Exponent underflow & \(\square\) OP 2 NOT ON FULLWORD BOUNDARY \\
\hline \(\square\) FIXED-POINT DIVIDE & OP 2 NOT ON DOUBLE-WORD \\
\hline \(\square\) FIXED-POINT OVERFLOW & BOUNDARY \\
\hline \(\square\) FLOATING-POINT DIVIDE & OP 1 NOT EVEN NUMBERED REGISTER \\
\hline OPERATION & NONE \\
\hline
\end{tabular}

The add normalized, long format (AD) instruction causes the contents of the double word in storage specified by operand 2 to be algebraically added to the contents of the doubleword register specified by operand \(1\left(r_{1}\right)\). The sum is normalized and placed in the operand \(1\left(r_{1}\right)\) register.

Explicit Format:
\begin{tabular}{l|l|l} 
LABEL & \(\triangle\) OPERATION \(\Delta\) & \\
\hline & & OPERAND \\
[symbol] & AD & \(r_{1}, \mathrm{~d}_{2}\left(\mathrm{x}_{2}, \mathrm{~b}_{2}\right)\) \\
ADLONG & AD & R4,50(R7,R8)
\end{tabular}

Implicit Format:
\begin{tabular}{l|l|l} 
LABEL & \(\triangle\) OPERATION \(\Delta\) & \\
\hline [symbol] & AD & \(r_{1}, s_{2}\left(x_{2}\right)\) \\
ADLONG & AD & R4,FAM
\end{tabular}

\section*{Operational Considerations:}
- 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 signficant 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 lost.
- 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 exists. 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.
- The sign of an arithmetic result is determined algebraically. The sign of a result with a zero fraction is always positive.

\section*{Example:}
\begin{tabular}{llll} 
LABEL & \(\triangle O P E R A T I O N \Delta\) & OPERAND \\
1 & 10 & 16 & \\
\hline ADLONG & AD & R4,FAM & \\
FAM & DC & \(D^{\prime} 1 \emptyset \emptyset^{\prime}\) &
\end{tabular}

Before execution of the add normalized, long format (AD) instruction, if we assume a value of +50 in R4, the contents of R4 and storage area FAM will be:

R4 before execution:
\begin{tabular}{|l|l|l|l|l|l|l|l|l|l|l|l|l|l|l|l|}
\hline 4 & 2 & 3 & 2 & 0 & 0 & 0 & 0 & 0 & 0 & 0 & 0 & 0 & 0 & 0 & 0 \\
\hline
\end{tabular}

FAM before and after execution:


R4 after execution:


\section*{ADR}

\subsection*{11.3. ADD NORMALIZED, LONG FORMAT (ADR)}


The add normalized, long format (ADR) instruction causes the contents of the doubl :-word register specified by operand \(2\left(r_{2}\right)\) to be algebraically added to the contents of the doubleword register specified by operand \(1\left(r_{1}\right)\). The sum is normalized and placed in the operand \(1\left(r_{1}\right)\) register.

Explicit and Implicit Format:
\begin{tabular}{l|l|l} 
LABEL & \(\triangle\) OPERATION \(\triangle\) & \\
\hline [symbol] & ADR & \(r_{1}, r_{2}\) \\
ADLONG & ADR & R4,R6
\end{tabular}

Operational Considerations:

\section*{- 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 a smaller exponent. Each hexadecimal digit shift to the right causes the exponent to be increased by 1 . After equalization, the fraction 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 lost.
- 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 correct value. If the exponent underflow mask of the current PSW is zero, the result is a true zero.

\section*{- Zero Result}

If the intermediate sum, including the guard digit, is zero, a significance exception exists. 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.
- The sign of an arithmetic result is determined algebraically. The sign of a result with a zero fraction is always positive.

Example:
\begin{tabular}{|c|c|c|c|}
\hline LABEL & \multicolumn{2}{|l|}{\(\triangle O P E R A T I O N \triangle\)} & \multirow[t]{2}{*}{OPERAND} \\
\hline 1 & 10 & 16 & \\
\hline ADLONG & ADR & & \\
\hline
\end{tabular}

Before execution of the add normalized, long format (ADR) instruction, if we assume a value of +50 in R4 and +100 in R6, the contents of the R4 and R6 will be:

R4 before execution:


R6 before and after execution:


R4 after execution:


\subsection*{11.4. ADD NORMALIZED, SHORT FORMAT (AE)}
\begin{tabular}{|c|c|c|c|}
\hline \multicolumn{4}{|c|}{ General } \\
\hline OPCODE & FORMAT & \begin{tabular}{l} 
OBJECT \\
INST. \\
TYPE
\end{tabular} \\
\begin{tabular}{c|c|c|} 
LGTH. \\
(BYTES)
\end{tabular} \\
\hline MNEM. & HEX. & RX & 4 \\
\hline AE & 7A & RX & \\
\hline
\end{tabular}
\begin{tabular}{|c|c|}
\hline \multicolumn{2}{|r|}{Possible Program Exceptions} \\
\hline \begin{tabular}{l}
ADDRESSING \\
data (INVALID SIGN/DIGIT)
decimal divide
decimal overflow
ExECUTE
EXPONENT OVERFLOW
EXPONENT UNDERFLOW
FIXED-POINT DIVIDE
FIXED-POINT OVERFLOW
floating-point divide
operation
\end{tabular} & \begin{tabular}{l}
PROTECTION \\
SIGNIFICANCE \\
SPECIFICATION: \\
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 \\
OP 2 NOT ON DOUBLE-WORD \\
BOUNDARY \\
op 1 NOT EVEN NUMBERED REGIStER \\
op 1 NOT ODD NUMBERED REGISTER \\
NONE
\end{tabular} \\
\hline
\end{tabular}

The add normalized, short format (AE) instruction 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\left(r_{1}\right)\). The sum is normalized and placed in the full word in the operand \(1\left(r_{1}\right)\) register.

\section*{Explicit Format:}
\begin{tabular}{l|l|l} 
LABEL & \(\triangle\) OPERATION \(\Delta\) & \\
\hline OPymbol] & AE & \\
ADSHORT & AE & \(r_{1}, d_{2}\left(x_{2}, b_{2}\right)\) \\
& & R4,50(R7,R8)
\end{tabular}

Implicit Format:
\begin{tabular}{l|l|l} 
LABEL & \(\triangle\) OPERATION \(\Delta\) & \\
\hline & & OPERAND \\
[symbol & AE & \(r_{1}, s_{2}\left(x_{2}\right)\) \\
ADSHORT & AE & R4,FAM
\end{tabular}

\section*{Operational Considerations:}

\section*{- 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 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.

\section*{- Normalization}

The intermediate sum is composed of six 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 lost.
- 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 correct value. If the exponent underflow mask of the current PSW is zero, the result is a true zero.

\section*{- Zero Result}

If the intermediate sum, including the guard digit, is zero, a significance exception exists. 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.
- The sign of an arithmetic result is determined algebraically. The sign of a result with a zero fraction is always positive.

\section*{Example:}
\begin{tabular}{|c|c|c|c|}
\hline LABEL & \multicolumn{2}{|l|}{\(\triangle\) PPERATIONA} & \multirow[t]{2}{*}{OPERAND} \\
\hline 1 & 10 & 16 & \\
\hline ADSHORT & AE & & \\
\hline FAM & DC & & \\
\hline
\end{tabular}

Before execution of the add normalized, short format (AE) instruction, if we assume a value of +50 in R4, the contents of R4 and storage area FAM will be:

R4 before execution:
\begin{tabular}{|l|l|l|l|l|l|l|l|}
\hline 4 & 2 & 3 & 2 & 0 & 0 & 0 & 0 \\
\hline
\end{tabular}

FAM before and after execution:


R4 after execution:
\begin{tabular}{|l|l|l|l|l|l|l|l|}
\hline 4 & 2 & 9 & 6 & 0 & 0 & 0 & 0 \\
\hline
\end{tabular}

\section*{AER}

\subsection*{11.5. ADD NORMALIZED, SHORT FORMAT (AER)}
\begin{tabular}{|c|c|c|c|c|c|c|}
\hline \multicolumn{4}{|c|}{General} & \multicolumn{3}{|r|}{Possible Program Exceptions} \\
\hline \multicolumn{2}{|l|}{OPCODE} & \multirow[t]{2}{*}{\[
\begin{aligned}
& \text { FORMAT } \\
& \text { TYPE }
\end{aligned}
\]} & \multirow[t]{2}{*}{\begin{tabular}{l}
OBJECT \\
INST. \\
LGTH. \\
(BYTES)
\end{tabular}} & \multirow[t]{9}{*}{ADDRESSING
DATA (INVALIDSIGN/DIGIT)
DECIMAL DIVIDE
DECIMAL OVERFLOW
EXECUTE
EXPONENT OVERFLOW
EXPONENT UNDERFLOW
FIXED-POINT DIVIDE
FIXED-POINT OVERFLOW
FLOATING-POINT DIVIDE
OPERATION} & \multicolumn{2}{|l|}{\multirow[t]{9}{*}{\begin{tabular}{l}
PROTECTION \\
SIGNIFICANCE \\
SPECIFICATION: \\
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 \\
OP 2 NOT ON DOUBLE-WORD \\
BOUNDARY \\
OP 1 NOT EVEN NUMBERED REGISTER \\
OP 1 NOT ODD NUMBERED REGISTER \\
NONE
\end{tabular}}} \\
\hline MNEM. & HEX. & & & & & \\
\hline AER & 3A & RR & 2 & & & \\
\hline \multicolumn{4}{|c|}{\multirow[b]{2}{*}{Condition Codes}} & & & \\
\hline & & & & & & \\
\hline \multicolumn{4}{|l|}{\multirow[t]{4}{*}{IF RESULT \(=0\), SET TO 0 IF RESULT<0, SET TO 1 if RESULT \(>0\), SET TO 2 IF OVERFLOW, SET TO 3
\(\square\) UNCHANGED}} & & & \\
\hline & & & & & & \\
\hline & & & & & & \\
\hline & & & & & & \\
\hline
\end{tabular}

The add normalized, short format (AER) instruction causes the contents of a full word in the register specified by operand \(2\left(r_{2}\right)\) to be algebraically added to a full word in the register specified by operand \(1\left(r_{1}\right)\). The sum is normalized and placed in the operand \(1\left(r_{1}\right)\) register.

Explicit and Implicit Format:
\begin{tabular}{l|l|l} 
LABEL & \(\triangle\) OPERATION \(\Delta\) & \\
\hline [symbol] & AER & \(r_{1}, r_{2}\) \\
ADSHORT & AER & R2,R4
\end{tabular}

Operational Considerations:

\section*{- 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 six 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 lost.
- 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 correct value. If the exponent underflow mask of the current PSW is zero, the result is a true zero.

\section*{- Zero Result}

If the intermediate sum, including the guard digit, is zero, a significance exception exists. 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.
- The sign of an arithmetic result is determined algebraically. The sign of a result with a zero fraction is always positive.

\section*{Example:}
\begin{tabular}{lll} 
LABEL & \(\triangle O P E R A T I O N A\) & OPERAND \\
1 & 10 & 16
\end{tabular}
ADSHORT AER R2,R4

Before execution of the add normalized, short format (AER) instruction, if we assume a value of +50 in R 2 and +100 in R4, contents of R2 and R4 will be:

R2 before execution:
\begin{tabular}{|l|l|l|l|l|l|l|l|}
\hline 4 & 2 & 3 & 2 & 0 & 0 & 0 & 0 \\
\hline
\end{tabular}
\(+50\)

R4 before and after execution:
\begin{tabular}{|l|l|l|l|l|l|l|l|}
\hline 4 & 2 & 6 & 4 & 0 & 0 & 0 & 0 \\
\hline
\end{tabular}
\(+100\)

R2 after execution:
\begin{tabular}{|l|l|l|l|l|l|l|l|}
\hline 4 & 2 & 9 & 6 & 0 & 0 & 0 & 0 \\
\hline
\end{tabular}

\subsection*{11.6. ADD UNNORMALIZED, SHORT FORMAT (AU)}

\begin{tabular}{|c|c|}
\hline \multicolumn{2}{|r|}{Possible Program Exceptions} \\
\hline \begin{tabular}{l}
ADDRESSING \\
DATA (INVALID SIGN/DIGIT) \\
DECIMAL DIVIDE \\
DECIMAL OVERFLOW \\
EXECUTE \\
EXPONENT OVERFLOW \\
EXPONENT UNDERFLOW \\
FIXED-POINT DIVIDE \\
FIXED-POINT OVERFLOW \\
FLOATING-POINT DIVIDE OPERATION
\end{tabular} & \begin{tabular}{l}
PROTECTION \\
SIGNIFICANCE
SPECIFICATION: \\
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 \\
OP 2 NOT ON DOUBLE-WORD \\
BOUNDARY \\
OP 1 NOT EVEN NUMBERED REGISTER \\
OP 1 NOT ODD NUMBERED REGISTER \\
NONE
\end{tabular} \\
\hline
\end{tabular}

The add unnormalized, short format (AU) instruction 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\left(r_{1}\right)\). The sum is placed in the operand \(1\left(r_{1}\right)\) register.

Explicit Format:
\begin{tabular}{l|l|l} 
LABEL & \(\triangle\) OPERATION \(\triangle\) & \\
\hline [symbol] & AU & \\
ADSHORT & AU & \(r_{1}, d_{2}\left(x_{2}, b_{2}\right)\) \\
& & R4,50(R7,R8)
\end{tabular}

Implicit Format:
\begin{tabular}{l|l|l} 
LABEL & \(\triangle\) OPERATION \(\triangle\) & \\
\hline [symbol] & AU & \(r_{1}, s_{2}\left(x_{2}\right)\) \\
ADSHORT & AU & R4,FAM
\end{tabular}

Operational Consideration:
- The execution of the \(A U\) instruction is identical to the \(A E\) instruction (11.4) except that the sum is not normalized before being placed in operand 1.

Example:


Before execution of the add unnormalized, short format (AU) instruction, if we assume a value of +900 in R4, the contents of R4 and main storage area FAM will be:

R4 before execution:
\begin{tabular}{|l|l|l|l|l|l|l|l|}
\hline 4 & 4 & 0 & 3 & 8 & 4 & 0 & 0 \\
\hline
\end{tabular}
\(+900\)

FAM before and after execution:


R4 after execution:


\subsection*{11.7. ADD UNNORMALIZED, SHORT FORMAT (AUR)}


The add unnormalized, short format (AUR) instruction causes the contents of a full word in the register specified by operand \(2\left(r_{2}\right)\) to be algebraically added to a full word in the register specified by operand \(1\left(r_{1}\right)\). The sum is placed in the operand \(1\left(r_{1}\right)\) register.

Explicit and Implicit Format:
\begin{tabular}{l|l|l} 
LABEL & \(\triangle\) OPERATION \(\triangle\) & \\
\hline & & OPERAND \\
[symbol] & AUR & \(r_{1}, r_{2}\) \\
ADSHORT & AUR & R2,R4
\end{tabular}

Operational Consideration:
- The execution of the AUR instruction is identical to the AER instruction (11.5), except that the sum is not normalized before being placed in operand 1.

Example:
\begin{tabular}{llll} 
LABEL & \multicolumn{2}{l}{\(\triangle O P E R A T I O N \Delta\)} & OPERAND \\
\hline ADSHORT & AUR & R2,R4 & \\
\hline
\end{tabular}

Before execution of the add unnormalized, short format (AUR) instruction, if we assume a value of +900 in R2 and +100 in R4, the contents of R2 and R4 will be:

R2 before execution:

\(+900\)

R4 before and after execution:
\begin{tabular}{|l|l|l|l|l|l|l|l|}
\hline 4 & 4 & 0 & 0 & 6 & 4 & 0 & 0 \\
\hline
\end{tabular}\(+100\)

R2 after execution:
\begin{tabular}{|l|l|l|l|l|l|l|l|}
\hline 4 & 4 & 0 & 3 & \(E\) & 8 & 0 & 0 \\
\hline
\end{tabular}

\subsection*{11.8. ADD UNNORMALIZED, LONG FORMAT (AW)}
\begin{tabular}{|c|c|c|c|c|c|c|c|}
\hline \multicolumn{4}{|c|}{General} & \multicolumn{4}{|r|}{Possible Program Exceptions} \\
\hline \multicolumn{2}{|l|}{OPCODE} & \multirow[t]{2}{*}{FORMAT
TYPE} & \multirow[t]{2}{*}{\begin{tabular}{l}
OBJECT \\
INST. \\
LGTH. \\
(BYTES)
\end{tabular}} & \multirow[t]{9}{*}{ADDRESSING
DATA (INVALIDSIGN/DIGIT)
DECIMAL DIVIDE
DECIMAL OVERFLOW
EXECUTE
EXPONENT OVERFLOW
EXPONENT UNDERFLOW
FIXEDPOINT DIVIDE
FIXED-POINT OVERFLOW
FLOATING-POINT DIVIDE
OPERATION} & \multicolumn{3}{|l|}{\multirow[t]{9}{*}{\begin{tabular}{l}
PROTECTION \\
SIGNIFICANCE \\
SPECIFICATION: \\
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 \\
OP 2 NOT ON DOUBLEWORD \\
BOUNDARY \\
OP 1 NOT EVEN NUMBERED REGISTER \\
OP 1 NOT ODD NUMBERED REGISTER \\
NONE
\end{tabular}}} \\
\hline MNEM. & HEX. & & & & & & \\
\hline AW & 6E & RX & 4 & & & & \\
\hline \multicolumn{4}{|c|}{\multirow[b]{2}{*}{Condition Codes}} & & & & \\
\hline & & & & & & & \\
\hline \multicolumn{4}{|l|}{\multirow[t]{4}{*}{IF RESULT \(=0\), SET TO 0 IF RESULT<0, SET TO 1 IF RESULT \(>0\), SET TO 2 IF OVERFLOW, SET TO 3 UNCHANGED}} & & & & \\
\hline & & & & & & & \\
\hline & & & & & & & \\
\hline & & & & & & & \\
\hline
\end{tabular}

The add unnormalized, long format (AW) instruction 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\left(r_{1}\right)\). The sum is placed in the double word in the register specified by operand \(1\left(r_{1}\right)\).

Explicit Format:
\begin{tabular}{l|l|l} 
LABEL & DOPERATION \(\Delta\) & \\
\hline [symbol] & AW & \(\mathrm{r}_{1}, \mathrm{~d}_{2}\left(\mathrm{x}_{2}, \mathrm{~b}_{2}\right)\) \\
ADLONG & AW & R4,50(R7,R8)
\end{tabular}

Implicit Format:
\begin{tabular}{c|l|l} 
LABEL & \(\triangle\) OPERATION \(\Delta\) & \\
\hline [symbol] & AW & \(r_{1}, s_{2}\left(x_{2}\right)\) \\
ADLONG & AW & R4,FAM
\end{tabular}

\section*{Operational Consideration:}
- The execution of the AW instruction is identical to the AD instruction (11.2) except that the sum is not normalized before being placed in operand \(1\left(r_{1}\right)\).

\section*{Example:}
\begin{tabular}{|c|c|c|c|}
\hline LABEL & \multicolumn{2}{|l|}{\(\triangle O P E R A T I O N \triangle\)} & OPERAND \\
\hline 1 & 10 & 16 & \\
\hline ADLONG & AW & & \\
\hline FAM & DC & & \\
\hline
\end{tabular}

Before execution of the add unnormalized, long format (AW) instruction, if we assume a value of +900 in R4, the contents of R4 and storage area FAM will be:

R4 before execution:


FAM before and after execution:


R4 after execution:


\subsection*{11.9. ADD UNNORMALIZED, LONG FORMAT (AWR)}
\begin{tabular}{|c|c|c|c|c|c|c|}
\hline \multicolumn{4}{|c|}{General} & \multicolumn{3}{|r|}{Possible Program Exceptions} \\
\hline \multicolumn{2}{|l|}{OPCODE} & \multirow[t]{2}{*}{FORMAT TYPE} & \multirow[t]{2}{*}{\begin{tabular}{l}
OBJECT \\
INST. \\
LGTH. \\
(BYTES)
\end{tabular}} & \multirow[t]{9}{*}{ADDRESSING
DATA (INVALID SIGN/DIGIT)
DECIMAL DIVIDE
DECIMAL OVERFLOW
EXECUTE
EXPONENT OVERFLOW
EXPONENT UNDERFLOW
FIXED-POINT DIVIDE
FIXED-POINT OVERFLOW
FLOATING-POINT DIVIDE
OPERATION} & \multicolumn{2}{|l|}{\multirow[t]{9}{*}{\begin{tabular}{l}
PROTECTION
SIGNIFICANCE
SPECIFICATION: \\
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 OP 2 NOT ON DOUBLE-WORD BOUNDARY \\
OP 1 NOT EVEN NUMBERED REGISTER OP 1 NOT ODD NUMBERED REGISTER NONE
\end{tabular}}} \\
\hline MNEM. & HEX. & & & & & \\
\hline AWR & 2E & RR & 2 & & & \\
\hline \multicolumn{4}{|c|}{\multirow[b]{2}{*}{Condition Codes}} & & & \\
\hline & & & & & & \\
\hline \multicolumn{4}{|l|}{\multirow[t]{4}{*}{IF RESULT \(=0\), SET TO O if RESULT \(<0\), SET TO 1 IF RESULT \(>0\), SET TO 2 IF OVERFLOW, SET TO 3 UNCHANGED}} & & & \\
\hline & & & & & & \\
\hline & & & & & & \\
\hline & & & & & & \\
\hline
\end{tabular}

The add unnormalized, long format (AWR) instruction causes the contents of the doubleword register specified by operand \(2\left(r_{2}\right)\) to be algebraically added to the double-word contents of operand \(1\left(r_{1}\right)\). The sum is placed in the operand \(1\left(r_{1}\right)\) register.

Explicit and Implicit Format:
\begin{tabular}{l|l|l} 
LABEL & \(\triangle\) OPERATION \(\Delta\) & \\
\hline [symbol] & AWR & \(r_{1}, r_{2}\) \\
ADLONG & AWR & R4,R6
\end{tabular}

\section*{Operational Consideration:}
- The execution of the AWR instruction is identical to the ADR instruction (11.3) except that the sum is not normalized before being placed in operand \(1\left(r_{1}\right)\).

Example:
\begin{tabular}{lll} 
LABEL & \(\triangle O P E R A T I O N A\) & OPERAND \\
10 & 10 & 16
\end{tabular}

ADLONG AWR R4,R6

Before execution of the add unnormalized, long format (AWR) instruction, if we assume a value of +900 in R4 and +100 in R6, the contents of R4 and R6 will be:

R4 before execution:


R6 before and after execution:
\begin{tabular}{|l|l|l|l|l|l|l|l|l|l|l|l|l|l|l|l|}
\hline 4 & 4 & 0 & 0 & 6 & 4 & 0 & 0 & 0 & 0 & 0 & 0 & 0 & 0 & 0 & 0 \\
\hline
\end{tabular}

R4 after execution:

11.10. COMPARE, LONG FORMAT (CD)
\begin{tabular}{|c|c|c|c|}
\hline \multicolumn{4}{|c|}{ General } \\
\hline \multicolumn{3}{|c|}{ OPCODE } & \multirow{2}{c|}{\begin{tabular}{c} 
FORMAT \\
TYPE
\end{tabular}} \\
\begin{tabular}{c|c|c|}
\hline OBJECT \\
INST. \\
LGTH. \\
(BYTES)
\end{tabular} \\
\hline MNEM. & HEX. & \\
\hline CD & 69 & RX & 4 \\
\hline
\end{tabular}
\begin{tabular}{|c|c|}
\hline \multicolumn{2}{|r|}{Possible Program Exceptions} \\
\hline ADDRESSING
DATA (INVALIDSIGN/DIGIT)
DECIMAL DIVIDE
DECIMAL OVERFLOW
EXECUTE
EXPONENT OVERFLOW
EXPONENT UNDERFLOW
FIXED-POINT DIVIDE
FIXED-POINT OVERFLOW
FLOATING-POINT DIVIDE
OPERATION & \begin{tabular}{l}
PROTECTION
SIGNIFICANCE
SPECIFICATION: \\
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 OP 2 NOT ON DOUBLE-WORD BOUNDARY OP 1 NOT EVEN NUMBERED REGISTER OP 1 NOT ODD NUMBERED REGISTER NONE
\end{tabular} \\
\hline
\end{tabular}

The compare, long format (CD) instruction causes the contents of a double word in the register specified by operand \(1\left(r_{1}\right)\) 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.

\section*{Explicit Format:}
\begin{tabular}{l|l|l} 
LABEL & DOPERATION \(\Delta\) & \\
\hline & & OPERAND \\
[symbol] & CD & \(r_{1}, \mathrm{~d}_{2}\left(\mathrm{x}_{2}, \mathrm{~b}_{2}\right)\) \\
COMPAR & CD & \(\mathrm{R} 2,50(\mathrm{R7}, \mathrm{R9} 9)\)
\end{tabular}

Implicit Format:
\begin{tabular}{l|l|l} 
LABEL & \(\triangle\) OPERATION \(\Delta\) & \\
\hline Isymbol] & CD & \(r_{1}, s_{2}\left(x_{2}\right)\) \\
COMPAR & CD & R2,FAM
\end{tabular}

\section*{Operational Considerations:}
- 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.
- The condition code is set:
- to zero when operand 1 equals operand 2;
- to 1 when operand 1 is less then operand 2 ; and
- to 2 when operand 1 is greater than operand 2.

Code 3 is not used.
Examples:
\begin{tabular}{cccc} 
LABEL & \(\triangle O P E R A T I O N \Delta\) & OPERAND \\
1 & 10 & 16 &
\end{tabular}
\begin{tabular}{lll}
\hline COMPAR1 & CD & R2,FAM3 \\
COMPAR2 & CD & R2,FAM32 \\
COMPAR3 & CD & R2,FAM33 \\
FAM3 & DC & \(D^{\prime} 3^{\prime}\) \\
FAM32 & DC & \(D^{\prime} 32^{\prime}\) \\
FAM33 & DC & \(D^{\prime} 33^{\prime}\)
\end{tabular}

Before execution of the compare, long format (CD) instruction, if we assume a value of +32 in R2, then:
- Example 1 will set a condition code of 2.
- Example 2 will set a condition code of zero.
- Example 3 will set a condition code of 1.

\section*{CDR}

\subsection*{11.11. COMPARE, LONG FORMAT (CDR)}
\begin{tabular}{|c|c|c|c|}
\hline \multicolumn{4}{|c|}{General} \\
\hline \multicolumn{2}{|l|}{OPCODE} & \multirow[t]{2}{*}{\[
\begin{aligned}
& \text { FORMAT } \\
& \text { TYPE }
\end{aligned}
\]} & \multirow[t]{2}{*}{OBJEC INST LGTH (BYTES} \\
\hline MNEM. & HEX. & & \\
\hline CDR & 29 & RR & 2 \\
\hline \multicolumn{4}{|c|}{Condition Codes} \\
\hline \multicolumn{4}{|l|}{} \\
\hline
\end{tabular}
\begin{tabular}{|c|c|}
\hline \multicolumn{2}{|r|}{Possible Program Exceptions} \\
\hline ADDRESSING
DATA (INVALIDSIGN/DIGIT)
decimal divide
decimal overflow
ExECUTE
EXPONENT OVERFLOW
EXPONENT UNDERFLOW
FIXED-POINT DIVIDE
FIXED-POINT OVERFLOW
FLOATING POINT DIVIDE OPERATION & \begin{tabular}{l}
PROTECTION
SIGNIFICANCE
SPECIFICATION: \\
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 \\
OP 2 NOT ON DOUBLE-WORD \\
BOUNDARY \\
OP 1 NOT EVEN NUMBERED REGISTER \\
OP 1 NOT ODD NUMBERED REGISTER \\
NONE
\end{tabular} \\
\hline
\end{tabular}

The compare, long format (CDR) instruction causes the contents of a double word in the register specified by operand \(1\left(r_{1}\right)\) to be algebraically compared with the contents of a double word in the register specified by operand \(2\left(r_{2}\right)\). The condition code is set by this instruction.

Explicit and Implicit Format:
\begin{tabular}{l|l|l} 
LABEL & \(\triangle\) OPERATION \(\triangle\) & \\
\hline [symbol] & CDR & \(\mathrm{r}_{1}, \mathrm{r}_{2}\) \\
COMPAR & CDR & \(\mathrm{R2}, \mathrm{R} 6\)
\end{tabular}

Operational Considerations:
- 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.
- The condition code is set:
- to zero when operand 1 equals operand 2;
- to 1 when operand 1 is less than operand 2; and
- to 2 when operand 1 is greater than operand 2.

Code 3 is not used.

Examples:
\begin{tabular}{llll} 
LABEL & \(\triangle O P E R A T I O N A\) & OPERAND \\
1 & 10 & 16 & \\
\hline COMPARI & CDR & R2,R6 & \\
COMPAR2 & CDR & R2,R4 & \\
COMPAR3 & CDR & R2,Rø &
\end{tabular}

Before execution of the compare, long format (CDR) instruction, if we assume values of +32 in R2, +33 in R6, +32 in R4, and +0 in RO, then:
- Example 1 will set a condition code of 1.
- Example 2 will set a condition code of zero.
- Example 3 will set a condition code of 2.

\section*{CE}

\subsection*{11.12. COMPARE, SHORT FORMAT (CE)}
\begin{tabular}{|c|c|c|c|c|c|c|}
\hline \multicolumn{4}{|c|}{General} & \multicolumn{3}{|r|}{Possible Program Exceptions} \\
\hline \multicolumn{2}{|l|}{OPCODE} & \multirow[t]{2}{*}{FORMAT TYPE} & \multirow[t]{2}{*}{\begin{tabular}{l}
OBJECT \\
INST. \\
LGTH. \\
(BYTES)
\end{tabular}} & \multirow[t]{9}{*}{\begin{tabular}{l}
ADDRESSING
DATA (INVALIDSIGN/DIGIT)
DECIMAL DIVIDE
DECIMAL OVERFLOW
EXECUTE
EXPONENT OVERFLOW
EXPONENT UNDERFLOW
FIXED-POINT DIVIDE
FIXED-POINT OVERFLOW
FLOATING-POINT DIVIDE \\
OPERATION
\end{tabular}} & \multicolumn{2}{|l|}{\multirow[t]{9}{*}{\begin{tabular}{l}
PROTECTION \\
significance \\
SPECIFICATION: \\
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 \\
OP 2 NOT ON DOUBLEWORD \\
BOUNDARY \\
OP 1 NOT EVEN NUMBERED REGISTER \\
OP 1 NOT ODD NUMBERED REGISTER \\
NONE
\end{tabular}}} \\
\hline MNEM. & HEX. & & & & & \\
\hline CE & 79 & RX & 4 & & & \\
\hline \multicolumn{4}{|c|}{\multirow[b]{2}{*}{Condition Codes}} & & & \\
\hline & & & & & & \\
\hline \multicolumn{4}{|l|}{\multirow[t]{4}{*}{IF OPI = OP2, SET TO O IF OPI <OP2, SET TO 1 IF OPI >OP2, SET TO 2 IF OVERFLOW, SET TO 3 UNCHANGED}} & & & \\
\hline & & & & & & \\
\hline & & & & & & \\
\hline & & & & & & \\
\hline
\end{tabular}

The compare, short format (CE) instruction causes the contents of a full word in the register specified by operand \(1\left(r_{1}\right)\) to be algebraically compared with the contents of a full word in storage specified by operand 2. The condition code is set by this instruction.

Explicit Format:


Implicit Format:
\begin{tabular}{c|l|l} 
LABEL & DOPERATION \(\Delta\) & \\
\hline [symbol] & CE & \\
COMPAR & CE & \(r_{1}, s_{2}\left(x_{2}\right)\) \\
& & R2,FAM
\end{tabular}

Operational Considerations:
- 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.
- The condition code is set:
- to zero when operand 1 equals operand 2;
- to 1 when operand 1 is less than operand 2 ; and
- to 2 when operand 1 is greater than operand 2.

Code 3 is not used.
Examples:
\begin{tabular}{llll} 
LABEL & \multicolumn{2}{l}{\(\quad \triangle O P E R A T I O N \Delta\)} & OPERAND \\
\hline
\end{tabular}

Before execution of the compare, short format (CE) instructions, if we assume a value of +32 in R2, then:
- Example 1 will set a condition code of 2.
- Example 2 will set a condition code of zero.
- Example 3 will set a condition code of 1.

\section*{CER}

\subsection*{11.13. COMPARE, SHORT FORMAT (CER)}
\begin{tabular}{|c|c|c|c|c|c|}
\hline \multicolumn{4}{|c|}{General} & \multicolumn{2}{|r|}{Possible Program Exceptions} \\
\hline \multicolumn{2}{|l|}{OPCODE} & \multirow[t]{2}{*}{FORMAT TYPE} & \multirow[t]{2}{*}{} & \multirow[t]{5}{*}{ADDRESSING
data (invalidosign/Digit)
decimal divide
decimal overflow
execute
exponent overflow
Exponent underflow
fixed-point divide
FIXED-POINT OVERFLOW
floating-point divide
operation} & \multirow[t]{2}{*}{PROTECTION
significance
SPECIFICATION:} \\
\hline MNEM. & HEX. & & & & \\
\hline CER & 39 & RR & 2 & & \(\square\) OP 1 NOT ON HALF-WORD BOUNDARY \\
\hline \multicolumn{4}{|c|}{Condition Codes} & & OP 2 NOT ON HALF WORD BOUNDARY OP 2 NOT ON FULL-WORD BOUNDARY \\
\hline \multicolumn{4}{|l|}{\(\square I F O P I=O P 2\), SET TO O
IF OPI \(<\) OP2, SET TO 1
IF OPI > OP2, SET TO 2
IF OVERFLOW, SET TO 3
UNCHANGED} & & \begin{tabular}{l}
OP 2 NOT ON DOUBLE-WURD BOUNDARY \\
op 1 not even numbered register op 1 NOT ODD NUMBERED REGISTER NONE
\end{tabular} \\
\hline
\end{tabular}

The compare, short format (CER) instruction causes the full-word contents of the register specified by operand \(1\left(r_{1}\right)\) to be algebraically compared with the contents of a full word in the register specified by operand \(2\left(r_{2}\right)\). The condition code is set by this instruction.

Explicit and Implicit Format:
\begin{tabular}{l|l|l} 
LABEL & AOPERATION \(\Delta\) & \\
\hline [symbol] & CER & \(r_{1}, r_{2}\) \\
COMPAR & CER & OPERAND \\
& &
\end{tabular}

Operational Considerations:
- 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.
- The condition code is set:
- to zero when operand 1 equals operand 2;
- to 1 when operand 1 is less than operand 2; and
- to 2 when operand 1 is greater than operand 2;

Code 3 is not used.

Examples:
1 10}1
1 10}1
COMPARI CER R4,RØ
COMPAR2 CER R4,R2
COMPAR3 CER R4,R6

Before execution of the compare, short format (CER) instructions, if we assume values of +32 in R4, +3 in RO, +32 in R2, and +33 in R6, then
- Example 1 will set a condition code of 2.
- Example 2 will set a condition code of zero.
- Example 3 will set a condition code of 1 .

\subsection*{11.14. DIVIDE, LONG FORMAT (DD)}


The divide, long format (DD) instruction causes the double-word contents of the operand 1 \(\left(r_{1}\right)\) 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\left(r_{1}\right)\). Any remainder is not preserved.

\section*{Explicit Format:}
\begin{tabular}{l|l|l} 
LABEL & \(\triangle\) OPERATION \(\triangle\) & \\
\hline OPymbol] & DD & \(\mathrm{r}_{1}, \mathrm{~d}_{2}\left(\mathrm{x}_{2}, \mathrm{~b}_{2}\right)\) \\
DIVLONG & DD & \(\mathrm{R} 4,33(\mathrm{R}, \mathrm{R} 10)\)
\end{tabular}

Implicit Format:
\begin{tabular}{l|l|l} 
LABEL & \(\triangle\) OPERATION \(\triangle\) & \\
\hline [SYmbol] & DD & \(r_{1}, s_{2}\left(x_{2}\right)\) \\
DIVLONG & DD & R4,FAM
\end{tabular}

Operational Considerations:
- 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\left(r_{1}\right)\) 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.
Example:
\begin{tabular}{|c|c|c|}
\hline LABEL & \multicolumn{2}{|l|}{\(\triangle\) OPERATIONA} \\
\hline 1 & 10 & 16 \\
\hline dividug & DD & R4, FAM \\
\hline FAM & DC & D'5' \\
\hline
\end{tabular}

Before execution of the divide, long format (DD) instruction, if we assume a value of +1000 in R4, the contents of R4 and storage area FAM will be:

R4 before execution:


FAM before and after execution:
\begin{tabular}{|l|l|l|l|l|l|l|l|l|l|l|l|l|l|l|l|}
\hline 4 & 1 & 5 & 0 & 0 & 0 & 0 & 0 & 0 & 0 & 0 & 0 & 0 & 0 & 0 & 0 \\
\hline
\end{tabular}

R4 after execution:


\subsection*{11.15. DIVIDE, LONG FORMAT (DDR)}


The divide, long format (DDR) instruction causes the double-word contents of the operand \(1\left(r_{1}\right)\) register to be divided by the double-word contents of the operand \(2\left(r_{2}\right)\) register. The normalized quotient is placed in the operand \(1\left(r_{1}\right)\) register. Any remainder is not preserved.

Explicit and Implicit Format:
\begin{tabular}{l|l|ll} 
LABEL & DOPERATION \(\triangle\) & & OPERAND \\
\hline [symbol] & DDR & \(\mathrm{r}_{1}, \mathrm{r}_{2}\) & \\
DIVLONG & DDR & R2,R6 &
\end{tabular}

Operational Considerations:
- 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 or one digit position may be required. The exponent of the intermediate result is increased by 1 if the shift is necessary. All operand \(1\left(r_{1}\right)\) fraction digits are used in forming the quotient even if the normalized operand \(1\left(r_{1}\right)\) fraction is larger than the normalized operand \(2\left(r_{2}\right)\) 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.
- 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.

Example:


Before execution of the divide, long format (DDR) instruction, if we assume values of +1000 in R2 and +5 in R6, the contents of R2 and R6 will be:

R2 before execution:


R6 before and after execution:
\begin{tabular}{|l|l|l|l|l|l|l|l|l|l|l|l|l|l|l|l|}
\hline 4 & 1 & 5 & 0 & 0 & 0 & 0 & 0 & 0 & 0 & 0 & 0 & 0 & 0 & 0 & 0 \\
\hline
\end{tabular}

R2 after execution:

11.16. DIVIDE, SHORT FORMAT (DE)



The divide, short format (DE) instruction causes the full-word contents of the operand 1 ( \(r_{1}\) ) 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\left(r_{1}\right)\) register. Any remainder is not preserved.

Explicit Format:
\begin{tabular}{l|l|l} 
LABEL & SOPERATION \(\Delta\) & \\
\hline [symbol] & DE & \multicolumn{1}{c}{ OPERAND } \\
DIVSHORT & DE & \(\mathrm{r}_{1}, \mathrm{~d}_{2}\left(\mathrm{x}_{2}, \mathrm{~b}_{2}\right)\) \\
& & R4,32(R8,R9)
\end{tabular}

Implicit Format:
\begin{tabular}{l|l|l} 
LABEL & \(\triangle\) OPERATION \(\triangle\) & \\
\hline [symbol] & DE & \(r_{1}, s_{2}\left(x_{2}\right)\) \\
DIVSHORT & DE & R4,FAM
\end{tabular}

Operational Considerations:
- 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\left(r_{1}\right)\) fraction digits are used in forming the quotient even if the normalized operand \(1\left(r_{1}\right)\) 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.
- 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.

\section*{Example:}
\begin{tabular}{llll} 
LABEL & \multicolumn{2}{c}{\begin{tabular}{l} 
OPPERATION \\
10
\end{tabular}} & 16 \\
\hline DIVIDESH & DE & R4, FAM & OPERAND \\
FAM & DC & \(E^{\prime} 5^{\prime}\) &
\end{tabular}

Before execution of the divide, short format (DE) instruction, if we assume a value of +1000 in R4, the contents of R4 and storage area FAM will be:

R4 before execution:
\begin{tabular}{|l|l|l|l|l|l|l|l|}
\hline 4 & 3 & 3 & \(E\) & 8 & 0 & 0 & 0 \\
\hline
\end{tabular}\(\quad+1000\)

FAM before and after execution:


R4 after execution:
\begin{tabular}{|l|l|l|l|l|l|l|l|}
\hline 4 & 2 & \(C\) & 8 & 0 & 0 & 0 & 0 \\
\hline
\end{tabular}

\section*{DER}

\subsection*{11.17. DIVIDE, SHORT FORMAT (DER)}
\begin{tabular}{|c|c|c|c|}
\hline \multicolumn{4}{|c|}{ General } \\
\hline OPCODE & FORMAT & \begin{tabular}{l} 
OBJECT \\
INST. \\
TYPE \\
LGTH. \\
(BYTES)
\end{tabular} \\
\hline MNEM. & HEX. & & RR \\
\hline DER & 3D & RR \\
\hline
\end{tabular}
\begin{tabular}{|c|c|}
\hline \multicolumn{2}{|r|}{Possible Program Exceptions} \\
\hline \begin{tabular}{l}
ADDRESSING
DATA (INVALIDSIGN/DIGIT)
DECIMAL DIVIDE
DECIMAL OVERFLOW
EXECUTE
EXPONENT OVERFLOW
EXPONENT UNDERFLOW
FIXED-POINT DIVIDE
FIXED-POINT OVERFLOW
FLOATING-POINT DIVIDE \\
operation
\end{tabular} & \begin{tabular}{l}
PROTECTION
SIGNIFICANCE
SPECIFICATION: \\
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 \\
OP 2 NOT ON DOUBLE-WORD \\
BOUNDARY \\
OP 1 NOT EVEN NUMBERED REGISTER \\
OP 1 NOT ODD NUMBERED REGISTER \\
NONE
\end{tabular} \\
\hline
\end{tabular}

The divide, short format (DER) instruction causes the full-word contents of the operand 1 \(\left(r_{1}\right)\) register to be divided by the full-word contents of the operand \(2\left(r_{2}\right)\) register. The normalized quotient is placed in a full word in the operand \(1\left(r_{1}\right)\) register. Any remainder is not preserved.

Explicit and Implicit Format:


\section*{Operational Considerations:}
- 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\left(r_{1}\right)\) fraction digits are used in forming the quotient even if the normalized operand \(1\left(r_{1}\right)\) fraction is larger than the normalized operand \(2\left(r_{2}\right)\) 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.
- 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.

Example:
\(\begin{array}{lll}\text { LABEL } & \triangle O P E R A T I O N \Delta & \text { OPERAND } \\ 1 & 10 & 16\end{array}\)
```

1 10}1

```
DIVIDESH DER R4,R6

Before execution of the divide, short format (DER) instruction, if we assume values of +1000 in R4 and +5 in R6, the contents of R4 and R6 will be:

R4 before execution:


R6 before and after execution:
\begin{tabular}{|l|l|l|l|l|l|l|l|}
\hline 4 & 1 & 5 & 0 & 0 & 0 & 0 & 0 \\
\hline
\end{tabular}

R4 after execution:

11.18. HALVE, LONG FORMAT (HDR)
\begin{tabular}{|c|c|c|c|c|c|}
\hline \multicolumn{4}{|c|}{General} & \multicolumn{2}{|r|}{Possible Program Exceptions} \\
\hline \multicolumn{2}{|l|}{OPCODE} & \multirow[t]{2}{*}{FORMAT TYPE} & \multirow[t]{2}{*}{\begin{tabular}{l}
OBJECT \\
INST. \\
LGTH. \\
(BYTES)
\end{tabular}} & \multirow[t]{5}{*}{ADDRESSING
DATA (INVALID SIGN/DIGIT)
DECIMAL DIVIDE
DECIMAL OVERFLOW
EXECUTE
EXPONENT OVERFLOW
EXPONENT UNDERFLOW
FIXED-POINT DIVIDE
FIXED-POINT OVERFLOW
FLOATING-POINT DIVIDE OPERATION} & \multirow[t]{5}{*}{\begin{tabular}{l}
PROTECTION
SIGNIFICANCE
SPECIFICATION: \\
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 \\
OP 2 NOT ON DOUBLE-WORD \\
BOUNDARY \\
OP 1 NOT EVEN NUMBERED REGISTER \\
OP 1 NOT ODD NUMBERED REGISTER \\
NONE
\end{tabular}} \\
\hline MNEM. & HEX. & & & & \\
\hline HDR & 24 & RR & 2 & & \\
\hline \multicolumn{4}{|c|}{Condition Codes} & & \\
\hline \multicolumn{4}{|l|}{IF RESULT \(=0\), SET TO O IF RESULT < O, SET TO 1 IF RESULT \(>0\), SET TO 2 IF OVERFLOW, SET TO 3 UNCHANGED} & & \\
\hline
\end{tabular}

The halve, long format (HDR) instruction causes the double-word contents of the operand \(2\left(r_{2}\right)\) register to be divided by 2 . The normalized quotient is placed in the double-word operand \(1\left(r_{1}\right)\) register.

Explicit and Implicit Format:
\begin{tabular}{l|l|l} 
LABEL & DOPERATION \(\Delta\) & \\
\hline [symbol] & HDR & \\
HALVE & HDR & \(r_{1}, r_{2}\) \\
& & R4,R6
\end{tabular}

Operational Considerations:
- The fraction of operand \(2\left(r_{2}\right)\) 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\left(r_{1}\right)\) 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\left(r_{2}\right)\) is zero, the result is made a true zero, a normalization is not attempted, and a significance exception does not occur.

\section*{Example:}
\begin{tabular}{|c|c|c|c|}
\hline LABEL & \multicolumn{2}{|l|}{\(\triangle O P E R A T I O N \triangle\)} & \multirow[t]{2}{*}{OPERAND} \\
\hline 1 & 10 & 16 & \\
\hline HALF & HDR & & \\
\hline
\end{tabular}

Before execution of the halve, long format (HDR) instruction, if we assume values of +0 in R4 and +1000 in R6, the contents of R4 and R6 will be:


R6 before and after execution:
\begin{tabular}{|l|l|l|l|l|l|l|l|l|l|l|l|l|l|l|l|}
\hline 4 & 3 & 3 & \(E\) & 8 & 0 & 0 & 0 & 0 & 0 & 0 & 0 & 0 & 0 & 0 & 0 \\
\hline
\end{tabular}

R4 after execution:
\begin{tabular}{|l|l|l|l|l|l|l|l|l|l|l|l|l|l|l|l|}
\hline 4 & 3 & 1 & \(F\) & 4 & 0 & 0 & 0 & 0 & 0 & 0 & 0 & 0 & 0 & 0 & 0 \\
\hline
\end{tabular}

\subsection*{11.19. HALVE, SHORT FORMAT (HER)}


The halve, short format (HER) instruction causes the full-word contents of the operand 2 \(\left(r_{2}\right)\) register to be divided by 2 . The normalized quotient is placed in the full word in the operand \(1\left(r_{1}\right)\) register.

Explicit and Implicit Format:
\begin{tabular}{l|l|l} 
LABEL & \(\triangle\) OPERATION \(\triangle\) & \\
\hline [symbol] & HER & \(\mathrm{r}_{1}, \mathrm{r}_{2}\) \\
HALVE & HER & R4,R6
\end{tabular}

\section*{Operational Considerations:}
- The fraction of operand \(2\left(r_{2}\right)\) 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\left(r_{1}\right)\) 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\left(r_{2}\right)\) is zero, the result is made a true zero, normalization is not attempted, and a significance exception does not occur.

\section*{Example:}
\begin{tabular}{lll} 
LABEL & \multicolumn{2}{l}{ OPPERATION } \\
1 & 10 & 16 \\
\hline
\end{tabular}

HALF HER R4,R6
Before execution of the halve, short format (HER) instruction, if we assume values of +1000 in R4 and +0 in R6, the contents of R6 and R4 will be:

R4 before execution:
\begin{tabular}{|l|l|l|l|l|l|l|l|}
\hline 0 & 0 & 0 & 0 & 0 & 0 & 0 & 0 \\
\hline
\end{tabular}
\(+0\)

R6 before and after execution:
\begin{tabular}{|l|l|l|l|l|l|l|l|}
\hline 4 & 3 & 3 & \(E\) & 8 & 0 & 0 & 0 \\
\hline
\end{tabular}
\(+1000\)

R4 after execution:
\begin{tabular}{|l|l|l|l|l|l|l|l|}
\hline 4 & 3 & 1 & \(F\) & 4 & 0 & 0 & 0 \\
\hline
\end{tabular}

\subsection*{11.20. LOAD COMPLEMENT, LONG FORMAT (LCDR)}

\begin{tabular}{|c|c|}
\hline \multicolumn{2}{|r|}{Possible Program Exceptions} \\
\hline ADDRESSING
DATA (INVALIDSIGN/DIGIT)
DECIMAL DIVIDE
DECIMAL OVERFLOW
EXECUTE
EXPONENT OVERFLOW
EXPONENT UNDERFLOW
FIXED-POINT DIVIDE
FIXED-POINT OVERFLOW
FLOATING-POINT DIVIDE
OPERATION & \begin{tabular}{l}
PROTECTION
SIGNIFICANCE
SPECIFICATION: \\
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 \\
OP 2 NOT ON DOUBLE-WORD \\
BOUNDARY \\
OP 1 NOT EVEN NUMBERED REGISTER \\
OP 1 NOT ODD NUMBERED REGISTER \\
NONE
\end{tabular} \\
\hline
\end{tabular}

The load complement, long format (LCDR) instruction causes the sign of the double-word contents of the operand \(2\left(r_{2}\right)\) register to be reversed. The result is placed in the double word in the operand \(1\left(r_{1}\right)\) register.

Explicit and Implicit Format:
\begin{tabular}{l|l|l} 
LABEL & \(\triangle\) OPERATION \(\triangle\) & \\
\hline [symbol] & LCDR & OPERAND \\
SIGN & LCDR & \(r_{1}, r_{2}\) \\
& & R6,R4
\end{tabular}

Operational Considerations:
- The exponent and fraction are not changed.
- The contents of operand \(2\left(r_{2}\right)\) remain unchanged.
- The condition code is set:
- to zero if result is zero;
- to 1 if result is less than zero; and
- to 2 if result is greater than zero.
- Code 3 is not used.

Example:


Before execution of the load complement, long format (LCDR) instruction, if we assume values of +1000 in R4 and +0 in R6, the contents of R6 and R4 will be:

R6 before execution:
\begin{tabular}{|l|l|l|l|l|l|l|l|l|l|l|l|l|l|l|l|}
\hline 0 & 0 & 0 & 0 & 0 & 0 & 0 & 0 & 0 & 0 & 0 & 0 & 0 & 0 & 0 & 0 \\
\hline
\end{tabular}

R4 before and after execution:


R6 after execution:


\subsection*{11.21. LOAD COMPLEMENT, SHORT FORMAT (LCER)}


The load complement, short format (LCER) instruction causes the sign of the full-word contents of the operand \(2\left(r_{2}\right)\) register to be reversed. The result is placed in the full word in the operand \(1\left(r_{1}\right)\) register.

Explicit and Implicit Format:
\begin{tabular}{l|l|ll} 
LABEL & & OPERATION \(\Delta\) & \\
\hline [symbol] & LCER & OPERAND \\
SIGN & LCER & \(r_{1}, r_{2}\) & \\
& & \(R 6, R 4\) &
\end{tabular}

Operational Considerations:
- The exponent and fraction are not changed.
- The contents of operand \(2\left(r_{2}\right)\) remain unchanged.
- The condition code is set:
- to zero if result is zero;
- to 1 if result is less than 0 ; and
- to 2 if result is greater than zero.

Code 3 is not used.

\section*{Example:}


Before execution of the load complement, short format (LCER) instruction, if we assume values of +1000 in R4 and +0 in R6, the contents of R6 and R4 will be:

R6 before execution:

\(+0\)

R4 before and after execution:

\(+1000\)

R6 after execution:


\section*{LD}
11.22. LOAD, LONG FORMAT (LD)
\begin{tabular}{|c|c|c|c|}
\hline \multicolumn{4}{|c|}{General} \\
\hline \multicolumn{2}{|l|}{opcode} & \multirow{2}{*}{FORMAT TYPE} & \multirow[t]{2}{*}{OBJECT INST. LGTH. (BYTES)} \\
\hline MNEM. & HEX. & & \\
\hline LD & 68 & RX & 4 \\
\hline \multicolumn{4}{|c|}{Condition Codes} \\
\hline \multicolumn{4}{|l|}{```
IF RESULT = 0, SET TO O
if RESULT<0, SET TO 1
if RESULT>0,SET TO 2
if overflow, set to 3
unchanged
```} \\
\hline
\end{tabular}
\begin{tabular}{|c|c|}
\hline \multicolumn{2}{|r|}{Possible Program Exceptions} \\
\hline \begin{tabular}{l}
ADDRESSING \\
DATA (INVALIDSIGN/DIGIT) \\
DECIMAL DIVIDE \\
DECIMAL OVERFLOW \\
EXECUTE \\
EXPONENT OVERFLOW \\
EXPONENT UNDERFLOW \\
FIXED-POINT DIVIDE \\
FIXED-POINT OVERFLOW \\
FLOATING-POINT DIVIDE \\
OPERATION
\end{tabular} & \begin{tabular}{l}
PROTECTION
SIGNIFICANCE
SPECIFICATION: \\
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 OP 2 NOT ON DOUBLE-WORD BOUNDARY OP 1 NOT EVEN NUMBERED REGISTER OP 1 NOT ODD NUMBERED REGISTER NONE
\end{tabular} \\
\hline
\end{tabular}

The load, long format (LD) instruction causes the contents of a double word in storage specified by operand 2 to be placed in the double word in the operand \(1\left(r_{1}\right)\) register.

\section*{Explicit Format:}
\begin{tabular}{l|l|l} 
LABEL & DOPERATION \(\Delta\) & \\
\hline OPERAND \\
[symbol] & LD & \(r_{1}, \mathrm{~d}_{2}\left(\mathrm{r}_{2}, \mathrm{~b}_{2}\right)\) \\
LOAD & LD & \(\mathrm{R4}, 33(\mathrm{R8}, \mathrm{R9})\)
\end{tabular}

Implicit Format:
\begin{tabular}{l|l|l} 
LABEL & \(\triangle\) OPERATION \(\Delta\) & \\
\hline [symbol] & LD & \(r_{1}, s_{2}\left(x_{2}\right)\) \\
LOAD & LD & R4,FAM
\end{tabular}

\section*{Operational Consideration:}
- The contents of operand 2 remain unchanged.

Example:


Before execution of the load, long format (LD) instruction, if we assume a value of +0 in R4, the contents of R4 and main storage area FAM will be:

R4 before execution:
\begin{tabular}{|l|l|l|l|l|l|l|l|l|l|l|l|l|l|l|l|}
\hline 0 & 0 & 0 & 0 & 0 & 0 & 0 & 0 & 0 & 0 & 0 & 0 & 0 & 0 & 0 & 0 \\
\hline
\end{tabular}

FAM before and after execution:
\begin{tabular}{|l|l|l|l|l|l|l|l|l|l|l|l|l|l|l|l|}
\hline 4 & 2 & 9 & 6 & 0 & 0 & 0 & 0 & 0 & 0 & 0 & 0 & 0 & 0 & 0 & 0 \\
\hline
\end{tabular}

R4 after execution:
\begin{tabular}{|l|l|l|l|l|l|l|l|l|l|l|l|l|l|l|l|}
\hline 4 & 2 & 9 & 6 & 0 & 0 & 0 & 0 & 0 & 0 & 0 & 0 & 0 & 0 & 0 & 0 \\
\hline
\end{tabular}

\subsection*{11.23. LOAD, LONG FORMAT (LDR)}
\begin{tabular}{|c|c|c|c|}
\hline \multicolumn{4}{|c|}{ General } \\
\hline OPCODE & FORMAT & \begin{tabular}{l} 
OBJECT \\
INST. \\
TYPE
\end{tabular} & \begin{tabular}{l} 
LGTH. \\
(BYTES)
\end{tabular} \\
\hline MNEM. & HEX. & RE & 2 \\
\hline LDR & 28 & RR & 2 \\
\hline
\end{tabular}
\begin{tabular}{|c|c|}
\hline \multicolumn{2}{|r|}{Possible Program Exceptions} \\
\hline ADDRESSING
DATA (INVALHDSIGN/DIGIT)
DECIMAL DIVIDE
DECIMAL OVERFLOW
EXECUTE
EXPONENT OVERFLOW
EXPONENT UNDERFLOW
FIXED-POINT DIVIDE
FIXED-POINT OVERFLOW
FLOATING-POINT DIVIDE operation & \begin{tabular}{l}
PROTECTION
SIGNIFICANCE
SPECIFICATION: \\
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 OP 2 NOT ON DOUBLE-WORD BOUNDARY \\
OP 1 NOT EVEN NUMBERED REGISTER \\
OP 1 NOT ODD NUMBERED REGISTER \\
NONE
\end{tabular} \\
\hline
\end{tabular}

The load, long format (LDR) instruction causes the contents of the double word in the operand \(2\left(r_{2}\right)\) register to be placed in the double word in the operand \(1\left(r_{1}\right)\) register.

Explicit and Implicit Format:
\begin{tabular}{l|l|l} 
LABEL & DOPERATION \(\Delta\) & \\
\hline [symbol] & LDR & \(r_{1}, r_{2}\) \\
LOAD & LDR & R6,R4
\end{tabular}

Operational Consideration:
- The contents of operand \(2\left(r_{2}\right)\) remain unchanged.

Example:
\begin{tabular}{|c|c|c|c|}
\hline LABEL & \multicolumn{2}{|l|}{\(\triangle\) PPERATIONA} & \multirow[t]{2}{*}{OPERAND} \\
\hline 1 & 10 & 16 & \\
\hline LOAD & LDR & & \\
\hline
\end{tabular}

Before execution of the load, long format (LDR) instruction, if we assume values of +150 in R4 and +0 in R6, the contents of R6 and R4 will be:

R6 before execution:


R4 before and after execution:


R6 after execution:

11.24. LOAD, SHORT FORMAT (LE)
\begin{tabular}{|c|c|c|c|}
\hline \multicolumn{4}{|c|}{ General } \\
\hline OPCODE & FORMAT & \begin{tabular}{l} 
OBJECT \\
INST. \\
TYPE
\end{tabular} & \begin{tabular}{l} 
LGTH. \\
(BYTES)
\end{tabular} \\
\hline MNEM. & HEX. & & RX \\
\hline LE & 78 & RX \\
\hline
\end{tabular}
\begin{tabular}{|c|c|}
\hline \multicolumn{2}{|r|}{Possible Program Exceptions} \\
\hline - ADDRESSING & \(\square\) PROTECTION \\
\hline \(\square\) DATA (INVALIDSIGN/DIGIT) & \(\square\) SIGNIFICANCE \\
\hline \(\square\) DECIMAL DIVIDE & \(\square\) SPECIFICATION: \\
\hline \(\square\) DECIMAL OVERFLOW & NOT A FLOATING-POINT REGISTER \\
\hline \(\square\) ExECute & \(\square\) OP 1 NOT ON HALF-WORD BOUNDARY \\
\hline \(\square\) EXPONENT OVERFLOW & \(\square\) OP 2 NOT ON HALF-WORD BOUNDARY \\
\hline \(\square\) EXPONENT UNDERFLOW & OP 2 NOT ON FULL-WORD BOUNDARY \\
\hline \(\square\) FIXED-POINT DIVIDE & \(\square\) OP 2 NOT ON DOUBLE-WORD \\
\hline \(\square\) FIXEDPOINT OVERFLOW & \(\square\) BOUNDARY \\
\hline FLOATING-POINT DIVIDE & OP 1 NOT EVEN NUMBERED REGISTER \\
\hline OPERATION & NONE \\
\hline
\end{tabular}

The load, short format (LE) instruction causes the contents of a full word in storage specified by operand 2 to be placed in a full word in the operand \(1\left(r_{1}\right)\) register.

\section*{Explicit Format:}
\begin{tabular}{l|l|ll} 
LABEL & DOPERATION \(\Delta\) & & OPERAND \\
\hline [symbol] & LE & \(r_{1}, \mathrm{~d}_{2}\left(\mathrm{x}_{2}, \mathrm{~b}_{2}\right)\) \\
LOAD & LE & \(\mathrm{R6}, 33(\mathrm{R8}, \mathrm{R9} 9)\)
\end{tabular}

Implicit Format:
\begin{tabular}{l|l|l} 
LABEL & \(\triangle\) OPERATION \(\Delta\) & \\
\hline OPERAND \\
[symbol] & LE & \(r_{1}, s_{2}\left(x_{2}\right)\) \\
LOAD & LE & R6,FAM
\end{tabular}

Operational Consideration:
- The contents of operand 2 remain unchanged.

Example:
\begin{tabular}{|c|c|c|c|}
\hline LABEL & \multicolumn{2}{|l|}{\(\triangle\) OPERATIONA} & OPERAND \\
\hline 1 & 10 & 16 & \\
\hline LOAD & LE & & \\
\hline FAM & DC & & \\
\hline
\end{tabular}

Before execution of the load, short format (LE) instruction, if we assume a value of +0 in R6, the contents of R6 and main storage area FAM will be:

R6 before execution:

+0

FAM before and after execution:


R6 after execution:
\begin{tabular}{|l|l|l|l|l|l|l|l|}
\hline 4 & 2 & 9 & 6 & 0 & 0 & 0 & 0 \\
\hline
\end{tabular}\(\quad+150\)

\subsection*{11.25. LOAD, SHORT FORMAT (LER)}
\begin{tabular}{|c|c|c|c|c|c|}
\hline \multicolumn{4}{|c|}{General} & \multicolumn{2}{|r|}{Possible Program Exceptions} \\
\hline \multicolumn{2}{|l|}{OPCODE} & \multirow[t]{2}{*}{\[
\begin{aligned}
& \text { FORMAT } \\
& \text { TYPE }
\end{aligned}
\]} & \multirow[t]{2}{*}{\begin{tabular}{l}
OBJECT \\
INST. \\
LGTH. \\
(BYTES)
\end{tabular}} & \multirow[t]{5}{*}{ADDRESSING
DATA (INVALIDSIGN/DIGIT)
DECIMAL DIVIDE
DECIMAL OVERFLOW
EXECUTE
EXPONENT OVERFLOW
EXPONENT UNDERFLOW
FIXED-POINT DIVIDE
FIXED-POINT OVERFLOW
FLOATING-POINT DIVIDE
OPERATION} & \multirow[t]{5}{*}{\begin{tabular}{l}
PROTECTION
SIGNIFICANCE
SPECIFICATION: \\
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 \\
OP 2 NOT ON DOUBLE-WORD \\
BOUNDARY \\
OP 1 NOT EVEN NUMBERED REGISTER \\
OP 1 NOT ODD NUMBERED REGISTER \\
NONE
\end{tabular}} \\
\hline MNEM. & HEX. & & & & \\
\hline LER & 38 & RR & 2 & & \\
\hline \multicolumn{4}{|c|}{Condition Codes} & & \\
\hline \multicolumn{4}{|l|}{IF RESULT \(=0\), SET TO 0 IF RESULT<0, SET TO 1 IF RESULT \(>0\), SET TO 2 IF OVERFLOW, SET TO 3 UNCHANGED} & & \\
\hline
\end{tabular}

The load, short format (LER) instruction causes the contents of a full word in the operand \(2\left(r_{2}\right)\) register to be placed in a full word in the operand \(1\left(r_{1}\right)\) register.

Explicit and Implicit Format:
\begin{tabular}{l|l|l} 
LABEL & \(\triangle\) OPERATION \(\Delta\) & \\
\hline [symbol] & LER & \(\mathrm{r}_{1}, \mathrm{r}_{2}\) \\
LOAD & LER & R6,R4
\end{tabular}

Operational Consideration:
- The contents of operand \(2\left(r_{2}\right)\) remain unchanged.

Example:


Before execution of the load, short format (LER) instruction, if we assume values of +150 in R4 and +0 in R6, the contents of R6 and R4 will be:

R6 before execution:
\begin{tabular}{|l|l|l|l|l|l|l|l|}
\hline 0 & 0 & 0 & 0 & 0 & 0 & 0 & 0 \\
\hline
\end{tabular}
\(+0\)

R4 before and after execution:

\(+150\)

R6 after execution:
\begin{tabular}{|l|l|l|l|l|l|l|l|}
\hline 4 & 2 & 9 & 6 & 0 & 0 & 0 & 0 \\
\hline
\end{tabular}
\(+150\)

\section*{LNDR}

\subsection*{11.26. LOAD NEGATIVE, LONG FORMAT (LNDR)}
\begin{tabular}{|c|c|c|c|}
\hline \multicolumn{4}{|c|}{ General } \\
\hline OPCODE & FORMAT & \begin{tabular}{l} 
OBJECT \\
INST. \\
TYPE \\
LGTH. \\
(BYTES)
\end{tabular} \\
\hline MNEM. & HEX. & & RYR \\
\hline LNDR & \(\mathbf{2 1}\) & RR & \(\mathbf{2}\) \\
\hline
\end{tabular}
\begin{tabular}{|c|}
\hline Condition Codes \\
\hline\(\square\) IF RESULT \(=0\), SET TO 0 \\
IFRESULT \(<0\), SET TO 1 \\
\(\square\) IF RESULT \(>0\), SET TO 2 \\
\(\square\) IF OVERFLOW, SET TO 3 \\
\(\square\) UNCHANGED \\
\hline
\end{tabular}
\begin{tabular}{|l|l|}
\hline \multicolumn{2}{|c|}{ Possible Program Exceptions } \\
\hline\(\square\) ADDRESSING & \(\square\) PROTECTION \\
\(\square\) DATA (INVALIDSIGN/DIGIT) & \(\square\) SIGNIFICANCE \\
\(\square\) DECIMAL DIVIDE & \(\square\) SPECIFICATION: \\
\(\square\) DECIMAL OVERFLOW & \(\square\) \\
\(\square\) EXECUTE & \(\square\) \\
\(\square\) NOT A FLOATING-POINT REGISTER \\
\(\square\) OP 1 NOT ON HALF-WORD BOUNDARY \\
\(\square\) EXPONENT UNDERFLOW & \(\square\) \\
\(\square\) FIXED-POINT DIVIDE & \(\square\) OP 2 NOT ON HALF-WORD BOUNDARY \\
\(\square\) FIXED-POINT OVERFLOW 2 NOT ON FULL-WORD BOUNDARY \\
\(\square\) FLOATING-POINT DIVIDE & \(\square\) OP 2 NOT ON DOUBLE-WORD \\
\(\square\) OPERATION & \(\square\) \\
\hline
\end{tabular}

The load negative, long format (LNDR) instruction causes the sign of the double word in the operand \(2\left(r_{2}\right)\) register to be made negative. The result is placed in the double-word register specified by operand \(1\left(r_{1}\right)\).

Explicit and Implicit Format:
\begin{tabular}{l|l|l} 
LABEL & \(\triangle\) OPERATION \(\Delta\) & \\
\hline [symbol] & LNDR & \(r_{1}, r_{2}\) \\
LOAD & LNDR & R2,R6
\end{tabular}

Operational Considerations:
- Operand \(2\left(r_{2}\right)\) is made negative even if the fraction is zero.
- The exponent and fraction are not changed.
- The contents of operand \(2\left(r_{2}\right)\) remain unchanged.
- The condition code is set:
- to zero if result is zero; and
- to 1 if result is less than zero.

Codes 2 and 3 are not used.

\section*{Example:}


Before execution of the load negative, long format (LNDR) instruction, if we assume values of +150 in R6 and +0 in R2, the contents of R2 and R6 will be:

R2 before execution:
\begin{tabular}{|l|l|l|l|l|l|l|l|l|l|l|l|l|l|l|l|}
\hline 0 & 0 & 0 & 0 & 0 & 0 & 0 & 0 & 0 & 0 & 0 & 0 & 0 & 0 & 0 & 0 \\
\hline
\end{tabular}

R6 before and after execution:
\begin{tabular}{|l|l|l|l|l|l|l|l|l|l|l|l|l|l|l|l|}
\hline 4 & 2 & 9 & 6 & 0 & 0 & 0 & 0 & 0 & 0 & 0 & 0 & 0 & 0 & 0 & 0 \\
\hline
\end{tabular}

R2 after execution:


\subsection*{11.27. LOAD NEGATIVE, SHORT FORMAT (LNER)}
\begin{tabular}{|c|c|c|c|c|c|c|}
\hline \multicolumn{4}{|c|}{General} & \multicolumn{3}{|r|}{Possible Program Exceptions} \\
\hline \multicolumn{2}{|l|}{OPCODE} & \multirow[t]{2}{*}{FORMAT TYPE} & \multirow[t]{2}{*}{\begin{tabular}{l}
OBJECT \\
INST. \\
LGTH. \\
(BYTES)
\end{tabular}} & \multirow[t]{5}{*}{\begin{tabular}{l}
ADDRESSING
DATA (INVALID SIGN/DIGIT)
DECIMAL DIVIDE
DECIMAL OVERFLOW
EXECUTE
EXPONENT OVERFLOW
EXPONENT UNDERFLOW
FIXED-POINT DIVIDE
FIXED-POINT OVERFLOW
FLOATING-POINT DIVIDE \\
OPERATION
\end{tabular}} & \multicolumn{2}{|l|}{\multirow[t]{5}{*}{\begin{tabular}{l}
PROTECTION
SIGNIFICANCE
SPECIFICATION: \\
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 OP 2 NOT ON DOUBLE-WORD BOUNDARY OP 1 NOT EVEN NUMBERED REGISTER OP 1 NOT ODD NUMBERED REGISTER NONE
\end{tabular}}} \\
\hline MNEM. & HEX. & & & & & \\
\hline LNER & 31 & RR & 2 & & & \\
\hline \multicolumn{4}{|c|}{Condition Codes} & & & \\
\hline \multicolumn{4}{|l|}{IF RESULT = 0, SET TO O if RESULT<O, SET TO 1 IF RESULT \(>0\) O, SET TO 2 IF OVERFLOW, SET TO 3 UNCHANGED} & & & \\
\hline
\end{tabular}

The load negative, short format (LNER) instruction causes the sign of a full word in the operand \(2\left(r_{2}\right)\) register to be made negative. The result is placed in a full word in the register specified by operand \(1\left(r_{1}\right)\).

Explicit and Implicit Format:
\begin{tabular}{l|l|l} 
LABEL & \(\triangle\) OPERATION \(\triangle\) & \\
\hline [symbol] & LNER & \(\mathrm{r}_{1}, \mathrm{r}_{2}\) \\
LOAD & LNER & R6,R4
\end{tabular}

\section*{Operational Considerations:}
- Operand \(2\left(r_{2}\right)\) is made negative even if the fraction is zero.
- The exponent and fraction are not changed.
- The contents of operand \(2\left(r_{2}\right)\) remain unchanged.
- The condition code is set:
- to zero if result is zero; and
- to 1 if result is less than zero.

Codes 2 and 3 are not used.

Example:


Before execution of the load negative, short format (LNER) instruction, if we assume values of +150 in R4 and +0 in R6, the contents of R6 and R4 will be:

R6 before execution:


R4 before and after execution:
\begin{tabular}{|l|l|l|l|l|l|l|l|}
\hline 4 & 2 & 9 & 6 & 0 & 0 & 0 & 0 \\
\hline
\end{tabular}

R6 after execution:
\begin{tabular}{|l|l|l|l|l|l|l|l|}
\hline\(c\) & 2 & 9 & 6 & 0 & 0 & 0 & 0 \\
\hline
\end{tabular}

\subsection*{11.28. LOAD POSITIVE, LONG FORMAT (LPDR)}
\begin{tabular}{|c|c|c|c|c|c|}
\hline \multicolumn{4}{|c|}{General} & \multicolumn{2}{|r|}{Possible Program Exceptions} \\
\hline \multicolumn{2}{|l|}{OPCODE} & \multirow[t]{2}{*}{FORMAT TYPE} & \multirow[t]{2}{*}{\begin{tabular}{l}
OBJECT \\
INST. \\
LGTH. \\
(BYTES)
\end{tabular}} & \multirow[t]{5}{*}{ADDRESSING
DATA (INVALIDSIGN/DIGIT)
DECIMAL DIVIDE
DECIMAL OVERFLOW
EXECUTE
EXPONENT OVERFLOW
EXPONENT UNDERFLOW
FIXED-POINT DIVIDE
FIXED-POINT OVERFLOW
FLOATING-POINT DIVIDE
OPERATION} & \multirow[t]{5}{*}{\begin{tabular}{l}
PROTECTION
SIGNIFICANCE
SPECIFICATION: \\
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 \\
OP 2 NOT ON DOUBLE-WORD \\
BOUNDARY \\
OP 1 NOT EVEN NUMBERED REGISTER \\
OP 1 NOT ODD NUMBERED REGISTER
NONE
\end{tabular}} \\
\hline MNEM. & HEX. & & & & \\
\hline LPDR & 20 & RR & 2 & & \\
\hline \multicolumn{4}{|c|}{Condition Codes} & & \\
\hline \multicolumn{4}{|l|}{IF RESULT \(=0\), SET TO O IF RESULT<0, SET TO 1 IF RESULT \(>0\) O. SET TO 2 IF OVERFLOW, SET TO 3
UNCHANGED} & & \\
\hline
\end{tabular}

The load positive, long format (LPDR) instruction causes the sign of the double word in the operand \(2\left(r_{2}\right)\) register to be positive, and the result is placed in the double word of the operand \(1\left(r_{1}\right)\) register.

Explicit and Implicit Format:
\begin{tabular}{l|l|l} 
LABEL & DOPERATION \(\triangle\) & \\
\hline [symbol] & LPDR & \(r_{1}, r_{2}\) \\
LOADN & LPDR & R4,R6
\end{tabular}

Operational Considerations:
- The exponent and fraction are not changed.
- The contents of operand \(2\left(r_{2}\right)\) remain unchanged.
- The condition code is set:
- to zero if result is zero; and
- to 2 if result is greater than zero.

Codes 1 and 3 are not used.

Example:


Before execution of the load positive, long format (LPDR) instruction, if we assume value of -150 in R4 and +0 in R6, the contents of R6 and R4 will be:

R6 before execution:
\begin{tabular}{|l|l|l|l|l|l|l|l|l|l|l|l|l|l|l|l|}
\hline 0 & 0 & 0 & 0 & 0 & 0 & 0 & 0 & 0 & 0 & 0 & 0 & 0 & 0 & 0 & 0 \\
\hline
\end{tabular}

R4 before and after execution:
\begin{tabular}{|l|l|l|l|l|l|l|l|l|l|l|l|l|l|l|l|}
\hline c & 1 & 2 & 9 & 6 & 0 & 0 & 0 & 0 & 0 & 0 & 0 & 0 & 0 & 0 & 0 \\
\hline
\end{tabular}

R6 after execution:
\begin{tabular}{|l|l|l|l|l|l|l|l|l|l|l|l|l|l|l|l|}
\hline 4 & 2 & 9 & 6 & 0 & 0 & 0 & 0 & 0 & 0 & 0 & 0 & 0 & 0 & 0 & 0 \\
\hline
\end{tabular}

\section*{LPER}

\subsection*{11.29. LOAD POSITIVE, SHORT FORMAT (LPER)}
\begin{tabular}{|c|c|c|c|}
\hline \multicolumn{4}{|c|}{ General } \\
\hline OPCODE & FORMAT & \begin{tabular}{l} 
OBJECT \\
INST. \\
TYPE \\
LGTH. \\
(BYTES)
\end{tabular} \\
\hline MNEM. & HEX. & \begin{tabular}{c} 
RY
\end{tabular} \\
\hline LPER & 30 & RR & 2 \\
\hline
\end{tabular}

Condition Codes
IF RESULT \(=0\), SET TO O
\(\square\) IF RESULT \(<0\), SET TO 1
\(\square\) IF RESULT \(>0\), SET TO 2
\(\square\) IF OVERFLOW, SET TO 3
\(\square\) UNCHANGED
\begin{tabular}{|c|c|}
\hline \multicolumn{2}{|r|}{Possible Program Exceptions} \\
\hline \begin{tabular}{l}
ADDRESSING \\
DATA (INVALIDSIGN/DIGIT)
DECIMAL DIVIDE
DECIMAL OVERFLOW
EXECUTE
EXPONENT OVERFLOW
EXPONENT UNDERFLOW
FIXED-POINT DIVIDE
FIXED-POINT OVERFLOW
FLOATINGPOINT DIVIDE OPERATION
\end{tabular} & \begin{tabular}{l}
PROTECTION
SIGNIFICANCE
SPECIFICATION: \\
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 \\
OP 2 NOT ON DOUBLE-WORD \\
BOUNDARY \\
OP 1 NOT EVEN NUMBERED REGISTER \\
OP 1 NOT ODD NUMBERED REGISTER \\
NONE
\end{tabular} \\
\hline
\end{tabular}

The load positive, short format (LPER) instruction causes the sign of a full word in the operand \(2\left(r_{2}\right)\) register to be positive. The result is placed in a full word of the operand 1 \(\left(r_{1}\right)\) register.

\section*{Explicit and Implicit Format:}
\begin{tabular}{c|l|l} 
LABEL & \(\triangle\) OPERATION \(\triangle\) & \\
\hline [symbol] & LPER & OPERAND \\
LOADP & LPER & \(r_{1}, r_{2}\) \\
& & \(R 6, R 4\)
\end{tabular}

\section*{Operational Considerations:}
- The exponent and fraction are not changed.
- The contents of operand \(2\left(r_{2}\right)\) remain unchanged.
- The condition code is set:
- to zero if result is zero; and
- to 2 if result is greater than zero.

Codes 1 and 3 are not used.

\section*{Example:}
\begin{tabular}{llll}
\begin{tabular}{lll} 
LABEL \\
1
\end{tabular} & \multicolumn{2}{l}{10} & 16 \\
\hline
\end{tabular}

Before execution of the load positive, short format (LPER) instruction, if we assume values of -150 in R4 and +0 in R6, the contents of R6 and R4 will be:

R6 before execution:

\(+0\)

R4 before and after execution:


R6 after execution:
\begin{tabular}{|l|l|l|l|l|l|l|l|}
\hline 4 & 2 & 9 & 6 & 0 & 0 & 0 & 0 \\
\hline
\end{tabular}

\subsection*{11.30. LOAD AND TEST, LONG FORMAT (LTDR)}
\begin{tabular}{|c|c|c|c|}
\hline \multicolumn{4}{|c|}{ General } \\
\hline \multicolumn{2}{|c|}{ OPCODE } & FORMAT & \begin{tabular}{l} 
OBJECT \\
INST. \\
TYPE
\end{tabular} \\
\begin{tabular}{c|c|c|} 
LGTH. \\
(BYTES)
\end{tabular} \\
\hline MNEM. & HEX. & RR & 2 \\
\hline LTDR & 22 & RR & \\
\hline
\end{tabular}

Condition Codes
- If Result = o, Set to o
- if result <o, set to 1
if result >o, SET TO 2
IF OVERFLOW, SET TO 3
unchanged
\begin{tabular}{|c|c|}
\hline \multicolumn{2}{|r|}{Possible Program Exceptions} \\
\hline ADDRESSING
DATA (INVALIDSIGN/DIGIT)
DECIMAL DIVIDE
DECIMAL OVERFLOW
EXECUTE
EXPONENT OVERFLOW
EXPONENT UNDERFLOW
FIXED-POINT DIVIDE
FIXED-POINT OVERFLOW
FLOATING-POINT DIVIDE
OPERATION & \begin{tabular}{l}
PROTECTION
SIGNIFICANCE
SPECIFICATION: \\
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 \\
OP 2 NOT ON DOUBLE-WORD \\
BOUNDARY \\
OP 1 NOT EVEN NUMBERED REGISTER \\
OP 1 NOT ODD NUMBERED REGISTER \\
NONE
\end{tabular} \\
\hline
\end{tabular}

The load and test, long format (LTDR) instruction causes the double-word contents of the operand \(2\left(r_{2}\right)\) register to be placed in the double-word operand \(1\left(r_{1}\right)\) register. The condition code is set by this instruction.

Explicit and Implicit Format:
\begin{tabular}{l|l|l} 
LABEL & \(\triangle\) OPERATION \(\triangle\) & \\
\hline [symbol] & LTDR & \(r_{1}, r_{2}\) \\
TEST & LTDR & R2,R6
\end{tabular}

\section*{Operational Considerations:}
- The contents of operand \(2\left(r_{2}\right)\) remain unchanged.
- When the same register is specified by operand \(1\left(r_{1}\right)\) and operand \(2\left(r_{2}\right)\), the operation is equivalent to a test without data movement.
- The condition code is set:
- to zero if result is zero;
- to 1 if result is less than zero; and
- to 2 if result is greater than zero.

Code 3 is not used.

Example:
LABEL

\section*{\(\triangle\) OPERATIONA}

OPERAND
\(1 \quad 10 \quad 16\)
TEST LTDR R2,R6

Before execution of the load and test, long format (LTDR) instruction, if we assume values of +150 in R6 and +0 in R2, the contents of R6 and R2 will be:

R2 before execution:


R6 before and after execution:


R2 after execution:
\begin{tabular}{|l|l|l|l|l|l|l|l|l|l|l|l|l|l|l|l|}
\hline 4 & 2 & 9 & 6 & 0 & 0 & 0 & 0 & 0 & 0 & 0 & 0 & 0 & 0 & 0 & 0 \\
\hline
\end{tabular}

The condition code is set to 2 because the result is greater than zero.

\subsection*{11.31. LOAD AND TEST, SHORT FORMAT (LTER)}


The load and test, short format (LTER) instruction causes the contents of a full word in the operand \(2\left(r_{2}\right)\) register to be placed in a full word in the operand \(1\left(r_{1}\right)\) register. The condition code is set by this instruction.

Explicit and Implicit Format:
\begin{tabular}{l|l|ll} 
LABEL & & OPPERATION \(\Delta\) & \\
\hline [symbol] & LTER & \(r_{1}, r_{2}\) & OPERAND \\
TEST & LTER & R6,R4 &
\end{tabular}

\section*{Operational Considerations:}
- The contents of operand \(2\left(r_{2}\right)\) remain unchanged.
- When the same register is specified by operand \(1\left(r_{1}\right)\) and operand \(2\left(r_{2}\right)\) the operation is equivalent to a test without data movement.
- The condition code is set:
- to zero if result is zero;
- to 1 if result is less than zero; and
- to 2 if result is greater than zero.

Code 3 is not used.

\section*{Example:}

LABEL \(\triangle\) OPERATION \(\triangle\)
1016

TEST LTER R6,R4
Before execution of the load and test, short format (LTER) instruction, if we assume values of +150 in R4 and +0 in R6, the contents of R4 and R6 will be:

R6 before execution:
\begin{tabular}{|l|l|l|l|l|l|l|l|}
\hline 0 & 0 & 0 & 0 & 0 & 0 & 0 & 0 \\
\hline
\end{tabular}
\(+0\)

R4 before and after execution:
\begin{tabular}{|l|l|l|l|l|l|l|l|}
\hline 4 & 2 & 9 & 6 & 0 & 0 & 0 & 0 \\
\hline
\end{tabular}

R6 after execution:
\begin{tabular}{|l|l|l|l|l|l|l|l|}
\hline 4 & 2 & 9 & 6 & 0 & 0 & 0 & 0 \\
\hline
\end{tabular}

The condition code is set to 2 because the result is greater than zero.

\subsection*{11.32. MULTIPLY, LONG FORMAT (MD)}
\begin{tabular}{|c|c|c|c|c|c|c|}
\hline \multicolumn{4}{|c|}{General} & \multicolumn{3}{|r|}{Possible Program Exceptions} \\
\hline \multicolumn{2}{|l|}{OPCODE} & \multirow[t]{2}{*}{FORMAT TYPE} & \multirow[t]{2}{*}{\begin{tabular}{l}
OBJECT \\
INST. \\
LGTH. \\
(BYTES)
\end{tabular}} & \multirow[t]{5}{*}{\begin{tabular}{l}
ADDRESSING
DATA (INVALIDSIGN/DIGIT)
DECIMAL DIVIDE
DECIMAL OVERFLOW
EXECUTE
EXPONENT OVERFLOW
EXPONENT UNDERFLOW
FIXED-POINT DIVIDE
FIXED-POINT OVERFLOW
FLOATING-POINT DIVIDE \\
OPERATION
\end{tabular}} & \multicolumn{2}{|l|}{\multirow[t]{5}{*}{\begin{tabular}{l}
PROTECTION
SIGNIFICANCE
SPECIFICATION: \\
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 \\
OP 2 NOT ON DOUBLE-WORD \\
BOUNDARY \\
OP 1 NOT EVEN NUMBERED REGISTER \\
OP 1 NOT ODD NUMBERED REGISTER \\
NONE
\end{tabular}}} \\
\hline MNEM. & HEX. & & & & & \\
\hline MD & 6C & RX & 4 & & & \\
\hline \multicolumn{4}{|c|}{Condition Codes} & & & \\
\hline \multicolumn{4}{|l|}{IF RESULT \(=0\), SET TO O
IF RESULT < O, SET TO 1
\(\square\) IF RESULT \(>0\), SET TO 2
IF OVERFLOW, SET TO 3 UNCHANGED} & & & \\
\hline
\end{tabular}

The multiply, long format (MD) instruction causes the contents of the double word in the operand \(1\left(r_{1}\right)\) 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\left(r_{1}\right)\) register.

\section*{Explicit Format:}
\begin{tabular}{l|l|l} 
LABEL & DOPERATION \(\Delta\) & \multicolumn{1}{c}{ OPERAND } \\
\hline [symbol] & MD & \(r_{1}, d_{2}\left(x_{2}, b_{2}\right)\) \\
MULT & MD & R4,32(R9,R10)
\end{tabular}

Implicit Format:
\begin{tabular}{l|l|l} 
LABEL & DOPERATION \(\triangle\) & \\
\hline [symbol] & MD & \(r_{1}, s_{2}\left(x_{2}\right)\) \\
MULT & MD & R4,FAM
\end{tabular}

\section*{Operational Considerations:}
- 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.

Example:
LABEL \(\triangle O P E R A T I O N \triangle \quad\) OPERAND
1010
\begin{tabular}{lll} 
MULTLG & MD & R4,FAM \\
FAM & DC & \(D^{\prime} 5 \emptyset^{\prime}\)
\end{tabular}

Before execution of the multiply, long format (MD) instruction, if we assume a value of -100 in R4, the contents of R4 and main storage area FAM will be:

R4 before execution:
\begin{tabular}{|l|l|l|l|l|l|l|l|l|l|l|l|l|l|l|l|}
\hline c & 2 & 6 & 4 & 0 & 0 & 0 & 0 & 0 & 0 & 0 & 0 & 0 & 0 & 0 & 0 \\
\hline
\end{tabular}

FAM before and after execution:
\begin{tabular}{|l|l|l|l|l|l|l|l|l|l|l|l|l|l|l|l|}
\hline 4 & 2 & 3 & 2 & 0 & 0 & 0 & 0 & 0 & 0 & 0 & 0 & 0 & 0 & 0 & 0 \\
\hline
\end{tabular}

R4 after execution:


\subsection*{11.33. MULTIPLY, LONG FORMAT (MDR)}
\begin{tabular}{|c|c|c|c|}
\hline \multicolumn{4}{|c|}{General} \\
\hline \multicolumn{2}{|l|}{OPCODE} & \multirow{2}{*}{\[
\begin{aligned}
& \text { FORMAT } \\
& \text { TYPE }
\end{aligned}
\]} & \multirow[t]{2}{*}{OBJECT INST. LGTH. (BYTES)} \\
\hline MNEM. & HEX. & & \\
\hline MDR & 2C & RR & 2 \\
\hline \multicolumn{4}{|c|}{Condition Codes} \\
\hline \multicolumn{4}{|l|}{F RESULT \(=0\), SET TO O if RESULT<0, SET TO 1 if RESULT \(>0\) o, SET TO 2 If overflow, set to 3 UNCHANGED} \\
\hline
\end{tabular}
\begin{tabular}{|c|c|}
\hline \multicolumn{2}{|r|}{Possible Program Exceptions} \\
\hline ADDRESSING
DATA (INVALIDSIGN/DIGIT)
DECIMAL DIVIDE
DECIMAL OVERFLOW
EXECUTE
EXPONENT OVERFLOW
EXPONENT UNDERFLOW
FIXED-POINT DIVIDE
FIXED-POINT OVERFLOW
FLOATING-POINT DIVIDE
OPERATION & \begin{tabular}{l}
PROTECTION
significance
SPECIFICATION: \\
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 \\
OP 2 NOT ON DOUBLE-WORD \\
BOUNDARY \\
OP 1 NOT EVEN NUMBERED REGISTER \\
OP 1 NOT ODD NUMBERED REGISTER \\
NONE
\end{tabular} \\
\hline
\end{tabular}

The multiply, long format (MDR) instruction causes the contents of the double word in the operand \(1\left(r_{1}\right)\) register to be multiplied by the contents of the double word in the operand 2 \(\left(r_{2}\right)\) register. The normalized product is placed in the double word of the operand 1 ( \(r_{1}\) ) register.

Explicit and Implicit Format:
\begin{tabular}{l|l|l} 
LABEL & \(\triangle\) OPERATION \(\Delta\) & \\
\hline [symbol] & MDR & \(r_{1}, r_{2}\) \\
MULT & MDRERAND \\
& & R4,R6
\end{tabular}

\section*{Operational Considerations:}
- 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 of 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.

Example:
\begin{tabular}{lll} 
LABEL & \(\triangle O P E R A T I O N \Delta\) & OPERAND \\
10 & 10 &
\end{tabular}

MULTREG MDR R4,R6
Before execution of the multiply, long format (MDR) instruction if we assume values of -100 in R4 and +50 in R6, the contents of R4 and R6 will be:

R4 before execution:
\begin{tabular}{|l|l|l|l|l|l|l|l|l|l|l|l|l|l|l|l|}
\hline c & 2 & 6 & 4 & 0 & 0 & 0 & 0 & 0 & 0 & 0 & 0 & 0 & 0 & 0 & 0 \\
\hline
\end{tabular}

R6 before and after execution:


R4 after execution:
\begin{tabular}{|l|l|l|l|l|l|l|l|l|l|l|l|l|l|l|l|}
\hline \(\mathbf{c}\) & 4 & 1 & 3 & 8 & 8 & 0 & 0 & 0 & 0 & 0 & 0 & 0 & 0 & 0 & 0 \\
\hline
\end{tabular}

\section*{ME}

\subsection*{11.34. MULTIPLY, SHORT FORMAT (ME)}
\begin{tabular}{|c|c|c|c|c|c|c|}
\hline \multicolumn{4}{|c|}{General} & \multicolumn{3}{|r|}{Possible Program Exceptions} \\
\hline \multicolumn{2}{|l|}{OPCODE} & \multirow[t]{2}{*}{FORMAT
TYPE} & \multirow[t]{2}{*}{\begin{tabular}{l}
OBJECT \\
INST. \\
LGTH. \\
(BYTES)
\end{tabular}} & \multirow[t]{9}{*}{\begin{tabular}{l}
ADDRESSING \\
DATA (INVALIDSIGN/DIGIT) \\
DECIMAL DIVIDE \\
DECIMAL OVERFLOW \\
EXECUTE \\
EXPONENT OVERFLOW \\
EXPONENT UNDERFLOW \\
FIXED-POINT DIVIDE \\
FIXED-POINT OVERFLOW \\
FLOATING-POINT DIVIDE \\
OPERATION
\end{tabular}} & \multicolumn{2}{|l|}{\multirow[t]{9}{*}{\begin{tabular}{l}
PROTECTION
SIGNIFICANCE
SPECIFICATION: \\
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 \\
OP 2 NOT ON DOUBLE-WORD \\
BOUNDARY \\
op 1 NOT EVEN NUMBERED REGISTER \\
OP 1 NOT ODD NUMBERED REGISTER \\
NONE
\end{tabular}}} \\
\hline MNEM. & HEX. & & & & & \\
\hline ME & 7C & RX & 4 & & & \\
\hline \multicolumn{4}{|c|}{\multirow[b]{2}{*}{Condition Codes}} & & & \\
\hline & & & & & & \\
\hline \multicolumn{4}{|l|}{\multirow[t]{4}{*}{IF RESULT \(=0\), SET TO 0 IF RESULT < O, SET TO 1 IF RESULT \(>0\), SET TO 2 IF OVERFLOW, SET TO 3 UNCHANGED}} & & & \\
\hline & & & & & & \\
\hline & & & & & & \\
\hline & & & & & & \\
\hline
\end{tabular}

The multiply, short format (ME) instruction causes the contents of a full word in the operand \(1\left(r_{1}\right)\) 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 \(\left(r_{1}\right)\) register.

\section*{Explicit Format:}
\begin{tabular}{l|l|l} 
LABEL & \(\triangle\) OPERATION \(\triangle\) & \multicolumn{1}{c}{ OPERAND } \\
\hline [symbol] & ME & \(r_{1}, \mathrm{~d}_{2}\left(\mathrm{x}_{2}, \mathrm{~b}_{2}\right)\) \\
MULT & ME & R6,32(R8,R12)
\end{tabular}

Implicit Format:
\begin{tabular}{l|l|l}
\multicolumn{1}{c|}{ LABEL } & DOPERATION \(\triangle\) & \\
\hline [symbol] & ME & \(\mathrm{r}_{1}, \mathrm{~s}_{2}\left(x_{2}\right)\) \\
MULT & ME & R6,FAM \\
& &
\end{tabular}

Operational Considerations:
- 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, the two least significant digits of which are zero, 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 exponent underflow or overflow does not occur.

Example:
\begin{tabular}{cccc} 
LABEL & \(\triangle\) OPERATION \(\triangle\) & OPERAND \\
1 & 10 & 16 &
\end{tabular}
\begin{tabular}{lll} 
MULT & ME & R6, FAM \\
FAM & DC & \(E^{\prime} 5 \emptyset^{\prime}\)
\end{tabular}

Before execution of the multiply, short format (ME) instruction, if we assume a value of -100 in R6, the contents of R6 and main storage area FAM will be:

R6 before execution:
\begin{tabular}{|l|l|l|l|l|l|l|l|}
\hline C & 2 & 6 & 4 & 0 & 0 & 0 & 0 \\
\hline
\end{tabular}

FAM before and after execution:
\begin{tabular}{|l|l|l|l|l|l|l|l|}
\hline 4 & 2 & 3 & 2 & 0 & 0 & 0 & 0 \\
\hline
\end{tabular}

R6 after execution:
\begin{tabular}{|l|l|l|l|l|l|l|l|}
\hline C & 4 & 1 & 3 & 8 & 8 & 0 & 0 \\
\hline
\end{tabular}

\section*{MER}

\subsection*{11.35. MULTIPLY, SHORT FORMAT (MER)}
\begin{tabular}{|c|c|c|c|c|c|c|}
\hline \multicolumn{4}{|c|}{General} & \multicolumn{3}{|r|}{Possible Program Exceptions} \\
\hline \multicolumn{2}{|l|}{OPCODE} & \multirow[t]{2}{*}{\[
\begin{aligned}
& \text { FORMAT } \\
& \text { TYPE }
\end{aligned}
\]} & \multirow[t]{2}{*}{\begin{tabular}{l}
OBJECT \\
INST. \\
LGTH. \\
(BYTES)
\end{tabular}} & \multirow[t]{5}{*}{ADDRESSING
DATA (INVALIDSIGN/DIGIT)
DECIMAL DIVIDE
DECIMAL OVERFLOW
EXECUTE
EXPONENT OVERFLOW
EXPONENT UNDERFLOW
FIXED-POINT DIVIDE
FIXED-POINT OVERFLOW
FLOATING-POINT DIVIDE
OPERATION} & \multicolumn{2}{|l|}{\multirow[t]{5}{*}{\begin{tabular}{l}
PROTECTION
SIGNIFICANCE
SPECIFICATION: \\
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 \\
OP 2 NOT ON DOUBLE-WORD \\
BOUNDARY \\
OP 1 NOT EVEN NUMBERED REGISTER \\
OP 1 NOT ODD NUMBERED REGISTER \\
NONE
\end{tabular}}} \\
\hline MNEM. & HEX. & & & & & \\
\hline MER & 3C & RR & 2 & & & \\
\hline \multicolumn{4}{|c|}{Condition Codes} & & & \\
\hline \multicolumn{4}{|l|}{IF RESULT \(=0\), SET TO 0
if RESULT<0, SET TO 1
if RESULT \(>0\), SET TO 2
IF OVERFLOW, SET TO 3 UNCHANGED} & & & \\
\hline
\end{tabular}

The multiply, short format (MER) instruction causes the contents of a full word in the operand \(1\left(r_{1}\right)\) register to be multiplied by the contents of a full word in the operand \(2\left(r_{2}\right)\) register. The normalized product is placed in a full word in the operand \(1\left(r_{1}\right)\) register.

Explicit and Implicit Format:
\begin{tabular}{l|l|l} 
LABEL & \(\triangle\) OPERATION \(\triangle\) & \\
\hline [symbol] & MER & \(r_{1}, r_{2}\) \\
MULT & MER & R6,R4
\end{tabular}

\section*{Operational Considerations:}
- 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, the two least significant digits of which are zero, 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.

\section*{Example:}
\begin{tabular}{lll} 
LABEL & \multicolumn{2}{c}{\(\Delta\) OPERAT ION \(\Delta\)} \\
10 & 16 \\
\hline MULT & MER & R6,R4
\end{tabular}

Before execution of the multip/y, short format (MER) instruction, if we assume values of -100 in R6 and +50 in R4, the contents of R6 and R4 will be:

R6 before execution:
\begin{tabular}{|l|l|l|l|l|l|l|l|}
\hline c & 2 & 6 & 4 & 0 & 0 & 0 & 0 \\
\hline
\end{tabular}

R4 before and after execution:
\begin{tabular}{|l|l|l|l|l|l|l|l|}
\hline 4 & 2 & 3 & 2 & 0 & 0 & 0 & 0 \\
\hline
\end{tabular}

R6 after execution:


\subsection*{11.36. SUBTRACT NORMALIZED, LONG FORMAT (SD)}
\begin{tabular}{|c|c|c|c|c|c|c|c|}
\hline \multicolumn{4}{|c|}{General} & \multicolumn{4}{|r|}{Possible Program Exceptions} \\
\hline \multicolumn{2}{|l|}{OPCODE} & \multirow[t]{2}{*}{\[
\begin{aligned}
& \text { FORMAT } \\
& \text { TYPE }
\end{aligned}
\]} & \multirow[t]{2}{*}{\begin{tabular}{l}
OBJECT \\
INST. \\
LGTH. \\
(BYTES)
\end{tabular}} & \multirow[t]{9}{*}{ADDRESSING
DATA (INVALID SIGN/DIGIT)
DECIMAL DIVIDE
DECIMAL OVERFLOW
EXECUTE
EXPONENT OVERFLOW
EXPONENT UNDERFLOW
FIXED-POINT DIVIDE
FIXED-POINT OVERFLOW
FLOATING-POINT DIVIDE
OPERATION} & \multicolumn{3}{|l|}{\multirow[t]{9}{*}{\begin{tabular}{l}
PROTECTION \\
SIGNIFICANCE \\
SPECIFICATION: \\
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 \\
OP 2 NOT ON DOUBLE-WORD \\
BOUNDARY \\
OP 1 NOT EVEN NUMBERED REGISTER \\
OP 1 NOT ODD NUMBERED REGISTER \\
NONE
\end{tabular}}} \\
\hline MNEM. & HEX. & & & & & & \\
\hline SD & 6B & RX & 4 & & & & \\
\hline \multicolumn{4}{|c|}{\multirow[b]{2}{*}{Condition Codes}} & & & & \\
\hline & & & & & & & \\
\hline \multicolumn{4}{|l|}{\multirow[t]{4}{*}{IF RESULT \(=0\), SET TO O IF RESULT < O, SET TO 1 IF RESULT \(>0\), SET TO 2
IF OVERFLOW, SET TO 3
\(\square\) UNCHANGED}} & & & & \\
\hline & & & & & & & \\
\hline & & & & & & & \\
\hline & & & & & & & \\
\hline
\end{tabular}

The subtract normalized, long format (SD) instruction 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\left(r_{1}\right)\). The normalized difference is placed in the operand \(1\left(r_{1}\right)\) register.

\section*{Explicit Format:}
\begin{tabular}{l|l|l} 
LABEL & \multicolumn{1}{|c|}{\(\triangle\) OPERATION \(\triangle\)} & \\
\hline [symbol] & SD & \multicolumn{1}{c}{ OPERAND } \\
SUB & SD & \(r_{1}, d_{2}\left(x_{2}, b_{2}\right)\) \\
& & R4,32(R7,R8)
\end{tabular}

Implicit Format:
\begin{tabular}{l|l|l} 
LABEL & \(\triangle\) OPERATION \(\Delta\) & \\
\hline [symbol] & SD & \(r_{1}, s_{2}\left(x_{2}\right)\) \\
SUB & SD & R4,FAM
\end{tabular}

Operational Considerations:
- The execution of the SD instruction is identical to that of the AD instruction (11.2), except that the sign of operand 2 is reversed before addition.
- The condition code is set:
- to zero if result fraction is zero;
- to 1 if result fraction is less than zero; and
- to 2 if result fraction is greater than zero.

Code 3 is not used.
Example:
\begin{tabular}{|c|c|c|c|}
\hline LABEL & \multicolumn{2}{|l|}{\(\triangle\) PPERATIONA} & OPERAND \\
\hline 1 & 10 & 16 & \\
\hline SUBLONG & SD & R4, FAM & \\
\hline FAM & DC & D'1ヵめ' & \\
\hline
\end{tabular}

Before execution of the subtract normalized, long format (SD) instruction if we assume a value of +250 in R4, the contents of R4 and main storage area FAM will be:

R4 before execution:
\begin{tabular}{|l|l|l|l|l|l|l|l|l|l|l|l|l|l|l|l|}
\hline 4 & 2 & F & A & 0 & 0 & 0 & 0 & 0 & 0 & 0 & 0 & 0 & 0 & 0 & 0 \\
\hline
\end{tabular}

FAM before and after execution:
\begin{tabular}{|l|l|l|l|l|l|l|l|l|l|l|l|l|l|l|l|}
\hline 4 & 2 & 6 & 4 & 0 & 0 & 0 & 0 & 0 & 0 & 0 & 0 & 0 & 0 & 0 & 0 \\
\hline
\end{tabular}

R4 after execution:

11.37. SUBTRACT NORMALIZED, LONG FORMAT (SDR)
\begin{tabular}{|c|c|c|c|c|c|c|c|}
\hline \multicolumn{4}{|c|}{General} & \multicolumn{4}{|c|}{s} \\
\hline \multicolumn{2}{|l|}{OPCODE} & \multirow[t]{2}{*}{\[
\begin{gathered}
\text { FORMAT } \\
\text { TYPE }
\end{gathered}
\]} & \multirow[t]{2}{*}{\begin{tabular}{l}
OBJECT \\
INST. \\
LGTH. \\
(BYTES)
\end{tabular}} & \multirow[t]{9}{*}{ADDRESSING
DATA (INVALIDSIGN/DIGIT)
DECIMAL DIVIDE
DECIMAL OVERFLOW
EXECUTE
EXPONENT OVERFLOW
EXPONENT UNDERFLOW
FIXED.POINT DIVIDE
FIXED-POINT OVERFLOW
FLOATING-POINT DIVIDE
OPERATION} & \multicolumn{3}{|l|}{\multirow[t]{9}{*}{\begin{tabular}{l}
PROTECTION
SIGNIFICANCE \\
SPECIFICATION: \\
NOT A FLOATINGPOINT REGISTER \\
OP 1 NOT ON HALF-WORD BOUNDARY \\
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
\end{tabular}}} \\
\hline MNEM. & HEX. & & & & & & \\
\hline SDR & 2B & RR & 2 & & & & \\
\hline \multicolumn{4}{|c|}{\multirow[b]{2}{*}{Condition Codes}} & & & & \\
\hline & & & & & & & \\
\hline \multicolumn{4}{|l|}{\multirow[t]{4}{*}{IF RESULT \(=0\), SET TO O if RESULT<0, SET TO 1 IF RESULT \(>0\), SET TO 2 IF OVERFLOW, SET TO 3 UNCHANGED}} & & & & \\
\hline & & & & & & & \\
\hline & & & & & & & \\
\hline & & & & & & & \\
\hline
\end{tabular}

The subtract normalized, long format (SDR) instruction causes the contents of the doubleword register, specified by operand \(2\left(r_{2}\right)\) to be algebraically subtracted from the contents of the double-word register, specified by operand \(1\left(r_{1}\right)\). The normalized difference is placed in the operand \(1\left(r_{1}\right)\) register.

Explicit and Implicit Format:
\begin{tabular}{l|l|l} 
LABEL & DOPERATION \(\triangle\) & \\
\hline [symbol] & SDR & \\
SUBTR & SDR & \(\mathrm{r}_{1}, \mathrm{r}_{2}\) \\
& & \(\mathrm{R6}, \mathrm{R4}\)
\end{tabular}

\section*{Operational Considerations:}
- The execution of the SDR instruction is identical to that of the ADR instruction (11.3), except that the sign of operand \(2\left(r_{2}\right)\) is reversed before addition.
- The condition code is set:
- to zero if result fraction is zero;
- to 1 if result fraction is less than zero; and
- to 2 if result fraction is greater than zero.

Code 3 is not used.

Example:
\begin{tabular}{llll} 
LABEL. & \multicolumn{2}{c}{\begin{tabular}{l} 
OPERATIONA \\
1
\end{tabular}} & 10 \\
\hline SUBTR & SDR & R6,R4 & OPERAND \\
\hline
\end{tabular}

Before execution of the subtract normalized, long format (SDR) instruction, if we assume values of +250 in R6 and +100 in R4, the contents of R6 and R4 will be:

R6 before execution:
\begin{tabular}{|l|l|l|l|l|l|l|l|l|l|l|l|l|l|l|l|}
\hline 4 & 2 & \(F\) & \(A\) & 0 & 0 & 0 & 0 & 0 & 0 & 0 & 0 & 0 & 0 & 0 & 0 \\
\hline
\end{tabular}

R4 before and after execution:


R6 after execution:
\begin{tabular}{|l|l|l|l|l|l|l|l|l|l|l|l|l|l|l|l|}
\hline 4 & 2 & 9 & 6 & 0 & 0 & 0 & 0 & 0 & 0 & 0 & 0 & 0 & 0 & 0 & 0 \\
\hline
\end{tabular}

\subsection*{11.38. SUBTRACT NORMALIZED, SHORT FORMAT (SE)}


The subtract normalized, short format (SE) instruction 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\left(r_{1}\right)\). The normalized difference is placed in the operand 1 \(\left(r_{1}\right)\) register.

\section*{Explicit Format:}
\begin{tabular}{l|l|l}
\multicolumn{1}{|c|}{ LABEL } & DOPERATION \(\Delta\) & \\
\hline [symbol] & SE & \\
SUB & SE & \(\mathrm{r}_{1}, \mathrm{~d}_{2}\left(\mathrm{x}_{2}, \mathrm{~b}_{2}\right)\) \\
& & \(\mathrm{R2}, 32(\mathrm{R9}, \mathrm{R} 10)\) \\
& &
\end{tabular}

Implicit Format:


Operational Considerations:
- The execution of the SE instruction is identical to that of the AE instruction (11.4), except that the sign of operand 2 is reversed before addition.
- The condition code is set:
- to zero if result fraction is zero;
- to 1 if result fraction is less than zero; and
- to 2 if result fraction is greater than zero.

Code 3 is not used.
Example:
```

LABEL \triangleOPERATION\triangle
1 10 16
SUBSHORT SE R2,FAM
FAM DC E'I\emptyset\emptyset'

```
                                    OPERAND

Before execution of the subtract normalized, short format (SE) instruction, if we assume a value of +250 in R2, the contents of R2 and main storage area FAM will be:

R2 before execution:
\begin{tabular}{|l|l|l|l|l|l|l|l|}
\hline 4 & 2 & \(F\) & \(A\) & 0 & 0 & 0 & 0 \\
\hline
\end{tabular}

FAM before and after execution:
\begin{tabular}{|l|l|l|l|l|l|l|l|}
\hline 4 & 2 & 6 & 4 & 0 & 0 & 0 & 0 \\
\hline
\end{tabular}

R2 after execution:
\begin{tabular}{|l|l|l|l|l|l|l|l|}
\hline 4 & 2 & 9 & 6 & 0 & 0 & 0 & 0 \\
\hline
\end{tabular}

\subsection*{11.39. SUBTRACT NORMALIZED, SHORT FORMAT (SER)}


The subtract normalized, short format (SER) instruction causes the contents of a full word in the operand \(2\left(r_{2}\right)\) register to be algebraically subtracted from a full word in the operand \(1\left(r_{1}\right)\). The normalized difference is placed in a full word in the operand \(1\left(r_{1}\right)\) register.

Explicit and Implicit Format:
\begin{tabular}{l|l|l} 
LABEL & \multicolumn{1}{|c|}{\(\triangle\) OPERATION \(\triangle\)} & \multicolumn{1}{c}{ OPERAND } \\
\hline [symbol] & SER & \(r_{1}, r_{2}\) \\
SUB & SER & R2,R4
\end{tabular}

\section*{Operational Considerations:}
- The execution of the SER instruction is identical to that of the AER instruction (11.5), except that the sign of operand 2 is reversed before addition.
- The condition code is set:
- to zero if result fraction is zero;
- to 1 if result fraction is less than zero; and
- to 2 if result fraction is greater than zero.

Code 3 is not used.

\section*{Example:}
\begin{tabular}{llll} 
LABEL & \(\triangle O P E R A T I O N \Delta\) & OPERAND \\
1 & 10 & 16 &
\end{tabular}

SUB SER R2,R4
Before execution of the subtract normalized, short format (SER) instruction, if we assume values of +250 in R2 and +100 in R4, the contents of R2 and R4 will be:

R2 before execution:
\begin{tabular}{|l|l|l|l|l|l|l|l|}
\hline 4 & 2 & \(F\) & \(A\) & 0 & 0 & 0 & 0 \\
\hline
\end{tabular}

R4 before and after execution:
\begin{tabular}{|l|l|l|l|l|l|l|l|}
\hline 4 & 2 & 6 & 4 & 0 & 0 & 0 & 0 \\
\hline
\end{tabular}
\(+100\)

R2 after execution:

11.40. STORE, LONG FORMAT (STD)
\begin{tabular}{|c|c|c|c|c|c|c|}
\hline \multicolumn{4}{|c|}{General} & \multicolumn{3}{|r|}{Possible Program Exceptions} \\
\hline \multicolumn{2}{|l|}{OPCODE} & \multirow[t]{2}{*}{\[
\begin{aligned}
& \text { FORMAT } \\
& \text { TYPE }
\end{aligned}
\]} & \multirow[t]{2}{*}{\begin{tabular}{l}
OBJECT \\
INST. \\
LGTH. \\
(BYTES)
\end{tabular}} & \multirow[t]{5}{*}{ADDRESSING
DATA (INVALIDSIGN/DIGIT)
DECIMAL DIVIDE
DECIMAL OVERFLOW
EXECUTE
EXPONENT OVERFLOW
EXPONENT UNDERFLOW
FIXED-POINT DIVIDE
FIXED-POINT OVERFLOW
FLOATING-POINT DIVIDE
OPERATION} & \multicolumn{2}{|l|}{\multirow[t]{5}{*}{\begin{tabular}{l}
PROTECTION
SIGNIFICANCE
SPECIFICATION: \\
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 OP 2 NOT ON DOUBLE-WORD BOUNDARY OP 1 NOT EVEN NUMBERED REGISTER OP 1 NOT ODD NUMBERED REGISTER NONE
\end{tabular}}} \\
\hline MNEM. & HEX. & & & & & \\
\hline STD & 60 & RX & 4 & & & \\
\hline \multicolumn{4}{|c|}{Condition Codes} & & & \\
\hline \multicolumn{4}{|l|}{IF RESULT \(=0\), SET TO O if RESULT<0, SET TO 1 IF RESULT \(>0\), SET TO 2 if overflow, set to 3 UNCHANGED} & & & \\
\hline
\end{tabular}

The store, long format (STD) instruction causes the contents of the register, specified by operand \(1\left(r_{1}\right)\), to be placed in a double word in main storage, specified by operand 2.

\section*{Explicit Format:}
\begin{tabular}{l|l|l} 
LABEL & DOPERATION \(\triangle\) & \\
\hline OPymbol] & STD & \(r_{1}, d_{2}\left(x_{2}, b_{2}\right)\) \\
STORE & STD & R4,32(R5,R6)
\end{tabular}

Implicit Format:
\begin{tabular}{l|l|l} 
LABEL & \(\triangle\) OPERATION \(\triangle\) & \\
\hline [symbol] & STD & \(r_{1}, s_{2}\left(x_{2}\right)\) \\
STORE & STD & R4,FAM
\end{tabular}

\section*{Operational Consideration:}
- The contents of the operand \(1\left(r_{1}\right)\) register remain unchanged.

Example:


Before execution of the store, long format (STD) instruction, if we assume a value of +500 in R4, the contents of R4 and main storage area FAM will be:

FAM before execution:


R4 before and after execution:
\begin{tabular}{|l|l|l|l|l|l|l|l|l|l|l|l|l|l|l|l|}
\hline 4 & 3 & 1 & F & 4 & 0 & 0 & 0 & 0 & 0 & 0 & 0 & 0 & 0 & 0 & 0 \\
\hline
\end{tabular}

FAM after execution:


\subsection*{11.41. STORE, SHORT FORMAT (STE)}
\begin{tabular}{|c|c|c|c|c|c|c|}
\hline \multicolumn{4}{|c|}{General} & \multicolumn{3}{|r|}{Possible Program Exceptions} \\
\hline \multicolumn{2}{|l|}{OPCODE} & \multirow[t]{2}{*}{FORMAT TYPE} & \multirow[t]{2}{*}{\begin{tabular}{l}
OBJECT \\
INST. \\
LGTH. \\
(BYTES)
\end{tabular}} & \multirow[t]{5}{*}{ADDRESSING
DATA (INVALIDSIGN/DIGIT)
DECIMAL DIVIDE
DECIMAL OVERFLOW
EXECUTE
EXPONENT OVERFLOW
EXPONENT UNDERFLOW
FIXED-POINT DIVIDE
FIXED-POINT OVERFLOW
FLOATING-POINT DIVIDE
OPERATION} & \multicolumn{2}{|l|}{\multirow[t]{5}{*}{\begin{tabular}{l}
PROTECTION
SIGNIFICANCE
SPECIFICATION: \\
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 OP 2 NOT ON DOUBLE-WORD BOUNDARY OP 1 NOT EVEN NUMBERED REGISTER OP 1 NOT ODD NUMBERED REGISTER NONE
\end{tabular}}} \\
\hline MNEM. & HEX. & & & & & \\
\hline STE & 70 & RX & 4 & & & \\
\hline \multicolumn{4}{|c|}{Condition Codes} & & & \\
\hline \multicolumn{4}{|l|}{IF RESULT \(=0\), SET TO O
IF RESULT < O, SET TO 1
IF RESULT \(>0\) O, SET TO 2
IF OVERFLOW, SET TO 3 UNCHANGED} & & & \\
\hline
\end{tabular}

The store, short format (STE) instruction causes the contents of a full word in the register, specified by operand \(1\left(r_{1}\right)\) to be placed in a full word in main storage, specified by operand 2.

Explicit Format:
\begin{tabular}{l|l|l}
\multicolumn{1}{c|}{ LABEL } & \(\triangle\) OPERATION \(\Delta\) & \\
\hline [symbol] & STE & \(r_{1}, d_{2}\left(x_{2}, b_{2}\right)\) \\
STORE & STE & R4,32(R5,R6)
\end{tabular}

Implicit Format:
\begin{tabular}{l|l|l} 
LABEL & DOPERATION \(\Delta\) & \\
\hline [symbol] & STE & \(r_{1}, s_{2}\left(x_{2}\right)\) \\
STORE & STE & R4,FAM
\end{tabular}

Operational Consideration:
- The contents of the operand \(1\left(r_{1}\right)\) register remain unchanged.

Example:
\begin{tabular}{llll}
\begin{tabular}{lll} 
LABEL & \multicolumn{2}{l}{} \\
1 & 10 & 16
\end{tabular} & OPERATIONA & \\
\hline STORE & STE & R4, FAM & \\
FAM & DC & \(E^{\prime} \emptyset^{\prime}\)
\end{tabular}

Before execution of the store, short format (STE) instruction, if we assume a value of +500 in R4, the contents of R4 and main storage FAM will be:

FAM before execution:
\begin{tabular}{|l|l|l|l|l|l|l|l|}
\hline 0 & 0 & 0 & 0 & 0 & 0 & 0 & 0 \\
\hline
\end{tabular}

R4 before and after execution:
\begin{tabular}{|l|l|l|l|l|l|l|l|}
\hline 4 & 3 & 1 & \(F\) & 4 & 0 & 0 & 0 \\
\hline
\end{tabular}

FAM after execution:


\subsection*{11.42. SUBTRACT UNNORMALIZED, SHORT FORMAT (SU)}
\begin{tabular}{|c|c|c|c|c|c|c|}
\hline \multicolumn{4}{|c|}{General} & \multicolumn{3}{|r|}{Possible Program Exceptions} \\
\hline \multicolumn{2}{|l|}{OPCODE} & \multirow[t]{2}{*}{FORMAT TYPE} & \multirow[t]{2}{*}{\begin{tabular}{l}
OBJECT \\
INST. \\
LGTH. \\
(BYTES)
\end{tabular}} & \multirow[t]{9}{*}{ADDRESSING
DATA (INVALID SIGN/DIGIT)
decimal divide
decimal overflow
EXECUTE
EXPONENT OVERFLOW
EXPONENT UNDERFLOW
FIXED-POINT DIVIDE
FIXED-POINT OVERFLOW
FLOATING-POINT DIVIDE
operation} & \multicolumn{2}{|l|}{\multirow[t]{9}{*}{\begin{tabular}{l}
PROTECTION \\
SIGNIFICANCE \\
SPECIFICATION: \\
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 \\
OP 2 NOT ON DOUBLE-WORD \\
BOUNDARY \\
OP 1 NOT EVEN NUMBERED REGISTER \\
OP 1 NOT ODD NUMBERED REGISTER \\
NONE
\end{tabular}}} \\
\hline MNEM. & HEX. & & & & & \\
\hline SU & 7F & RX & 4 & & & \\
\hline \multicolumn{4}{|c|}{\multirow[b]{2}{*}{Condition Codes}} & & & \\
\hline & & & & & & \\
\hline \multicolumn{4}{|l|}{\multirow[t]{4}{*}{IF RESULT \(=0\), SET TO O IF RESULT<O, SET TO 1 IF RESULT \(>0\) O, SET TO 2 IF OVERFLOW, SET TO 3
\(\square\) UNCHANGED}} & & & \\
\hline & & & & & & \\
\hline & & & & & & \\
\hline & & & & & & \\
\hline
\end{tabular}

The subtract unnormalized, short format (SU) instruction 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\left(r_{1}\right)\). The difference is placed in a full word in the operand \(1\left(r_{1}\right)\) register.

Explicit Format:
\begin{tabular}{l|l|l} 
LABEL & \(\triangle\) OPERATION \(\triangle\) & \\
\hline [symbol] & SU & \\
SUBERAND \\
SUB & SU & \(\mathrm{r}_{1}, \mathrm{~d}_{2}\left(\mathrm{x}_{2}, \mathrm{~b}_{2}\right)\) \\
& & \(\mathrm{R6}, 32\) (R7,R9)
\end{tabular}

Implicit Format:
\begin{tabular}{l|l|l} 
LABEL & \(\triangle\) OPERATION \(\Delta\) & \\
\hline OSymbol] & SU & \(r_{1}, s_{2}\left(x_{2}\right)\) \\
SUB & SU & R6,FAM
\end{tabular}

\section*{Operational Considerations:}
- The execution of the SU instruction is identical to that of the AU instruction (11.6), except that the sign is reversed before addition.
- The condition code is set:
- to zero if result fraction is zero;
- to 1 if result fraction is less than zero; and
- to 2 if result fraction is greater than zero.

Code 3 is not used.
Example:
\begin{tabular}{lll} 
SUBUNNOR SU & R6,FAM \\
FAM & DC & \(E^{\prime} 9 \emptyset \emptyset^{\prime}\)
\end{tabular}

Before execution of the subtract unnormalized, short format (SU) instruction, if we assume a value of +1000 in R6, the contents of \(R 6\) and main storage area FAM will be:

R6 before execution:
\begin{tabular}{|l|l|l|l|l|l|l|l|}
\hline 4 & 3 & 3 & \(E\) & 8 & 0 & 0 & 0 \\
\hline
\end{tabular}
\(+1000\)

FAM before and after execution:
\begin{tabular}{|l|l|l|l|l|l|l|l|}
\hline 4 & 3 & 3 & 8 & 4 & 0 & 0 & 0 \\
\hline
\end{tabular}
\[
+900
\]

R6 after execution:
\begin{tabular}{|l|l|l|l|l|l|l|l|}
\hline 4 & 3 & 0 & 6 & 4 & 0 & 0 & 0 \\
\hline
\end{tabular}

\subsection*{11.43. SUBTRACT UNNORMALIZED, SHORT FORMAT (SUR)}
\begin{tabular}{|c|c|c|c|c|c|c|}
\hline \multicolumn{4}{|c|}{General} & \multicolumn{3}{|r|}{Possible Program Exceptions} \\
\hline \multicolumn{2}{|l|}{OPCODE} & \multirow[t]{2}{*}{\[
\begin{aligned}
& \text { FORMAT } \\
& \text { TYPE }
\end{aligned}
\]} & \multirow[t]{2}{*}{\begin{tabular}{l}
OBJECT \\
INST. \\
LGTH. \\
(BYTES)
\end{tabular}} & \multirow[t]{9}{*}{ADDRESSING
DATA (INVALIDSIGN/DIGIT)
DECIMAL DIVIDE
DECIMAL OVERFLOW
EXECUTE
EXPONENT OVERFLOW
EXPONENT UNDERFLOW
FIXED-POINT DIVIDE
FIXED-POINT OVERFLOW
FLOATING-POINT DIVIDE
OPERATION} & \multicolumn{2}{|l|}{\multirow[t]{9}{*}{\begin{tabular}{l}
PROTECTION \\
SIGNIFICANCE \\
SPECIFICATION: \\
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 \\
OP 2 NOT ON DOUBLE-WORD \\
BOUNDARY \\
OP 1 NOT EVEN NUMBERED REGISTER \\
OP 1 NOT ODD NUMBERED REGISTER \\
NONE
\end{tabular}}} \\
\hline MNEM. & HEX. & & & & & \\
\hline SUR & 3F & RR & 2 & & & \\
\hline \multicolumn{4}{|c|}{\multirow[b]{2}{*}{Condition Codes}} & & & \\
\hline & & & & & & \\
\hline \multicolumn{4}{|l|}{\multirow[t]{4}{*}{IF RESULT \(=0\), SET TO O IF RESULT < O, SET TO 1 IF RESULT \(>0\), SET TO 2 IF OVERFLOW, SET TO 3 UNCHANGED}} & & & \\
\hline & & & & & & \\
\hline & & & & & & \\
\hline & & & & & & \\
\hline
\end{tabular}

The subtract unnormalized, short format (SUR) instruction causes the contents of a full word in the operand \(2\left(r_{2}\right)\) register to be algebraically subtracted from a full word in the operand \(1\left(r_{1}\right)\) register. The difference is placed in a full word in the operand \(1\left(r_{1}\right)\) register.

Explicit and Implicit Format:
\begin{tabular}{l|l|l} 
LABEL & \(\triangle\) OPERATION \(\Delta\) & \\
\hline [symbol] & SUR & \(r_{1}, r_{2}\) \\
SUB & SUR & R6,R4
\end{tabular}

Operational Considerations:
- The execution of the SUR instruction is identical to that of the AUR instruction (11.7), except that the sign is reversed before addition.
- The condition code is set:
- to zero if result fraction is zero;
- to 1 if result fraction is less than zero; and
- to 2 if result fraction is greater than zero.

Code 3 is not used.

Example:
LABEL
\(\triangle\) OPERATIONA
OPERAND
1
10
16

SUBSHORT SUR R6,R4
Before execution of the subtract unnormalized, short format (SUR) instruction, if we assume values of +1000 in R6 and +900 in R4, the contents of R6 and R4 will be:

R6 before execution:

\(+1000\)

R4 before and after execution:


R6 after execution:
\begin{tabular}{|l|l|l|l|l|l|l|l|}
\hline 4 & 3 & 0 & 6 & 4 & 0 & 0 & 0 \\
\hline
\end{tabular}

\subsection*{11.44. SUBTRACT UNNORMALIZED, LONG FORMAT (SW)}
\begin{tabular}{|c|c|c|c|c|c|c|}
\hline \multicolumn{4}{|c|}{General} & \multicolumn{3}{|r|}{Possible Program Exceptions} \\
\hline \multicolumn{2}{|l|}{OPCODE} & \multirow[t]{2}{*}{\[
\begin{aligned}
& \text { FORMAT } \\
& \text { TYPE }
\end{aligned}
\]} & \multirow[t]{2}{*}{OBJECT INST. LGTH. (BYTES)} & \multirow[t]{9}{*}{ADDRESSING
DATA (INVALIDSIGN/DIGIT)
DECIMAL DIVIDE
DECIMAL OVERFLOW
EXECUTE
EXPONENT OVERFLOW
EXPONENT UNDERFLOW
FIXED-POINT DIVIDE
FIXED-POINT OVERFLOW
FLOATING-POINT DIVIDE
OPERATION} & \multicolumn{2}{|l|}{\multirow[t]{9}{*}{\begin{tabular}{l}
PROTECTION \\
SIGNIFICANCE \\
SPECIFICATION: \\
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 \\
OP 2 NOT ON DOUBLE-WORD \\
BOUNDARY \\
OP 1 NOT EVEN NUMBERED REGISTER \\
OP 1 NOT ODD NUMBERED REGISTER \\
NONE
\end{tabular}}} \\
\hline MNEM. & HEX. & & & & & \\
\hline SW & \(6 F\) & RX & 4 & & & \\
\hline \multicolumn{4}{|c|}{\multirow[b]{2}{*}{Condition Codes}} & & & \\
\hline & & & & & & \\
\hline \multicolumn{4}{|l|}{\multirow[t]{4}{*}{\(\square\) IF RESULT \(=0\), SET TO O
\(\square\) IF RESULT \(<0\), SET TO 1
IF RESULT \(>0\), SET TO 2
\(\square\) IF OVERFLOW, SET TO 3
\(\square\) UNCHANGED}} & & & \\
\hline & & & & & & \\
\hline & & & & & & \\
\hline & & & & & & \\
\hline
\end{tabular}

The subtract unnormalized, long format (SW) instruction 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\left(r_{1}\right)\). The difference is placed in the double word operand \(1\left(r_{1}\right)\) register.

\section*{Explicit Format:}
\begin{tabular}{l|l|l} 
Label & DOPERATION \(\triangle\) & \\
\hline [symbol] & SW & \\
SUB & SW & \(\mathrm{r}_{1}, \mathrm{~d}_{2}\left(\mathrm{x}_{2}, \mathrm{~b}_{2}\right)\) \\
& & \(\mathrm{R4}, \mathrm{32}(\mathrm{R} 5, \mathrm{R} 9)\) \\
& &
\end{tabular}

Implicit Format:
\begin{tabular}{l|l|l} 
LABEL & \(\triangle\) OPERATION \(\Delta\) & \\
\hline [Symbol] & SW & \(r_{1}, s_{2}\left(x_{2}\right)\) \\
SUB & SW & R4,FAM
\end{tabular}

Operational Considerations:
- The execution of the SW instruction is identical to that of the AW instruction (11.8), except that the sign is reversed before addition.
- The condition code is set:
- to zero if result fraction is zero;
- to 1 if result fraction is less than 0 ; and
- to 2 if result fraction is greater than zero.

Code 3 is not used.
Example:
LABEL
1
\(\triangle O P E R A T I O N \triangle\)
OPERAND
1016
\begin{tabular}{lll}
\hline SUBUNNOR & SW & R4, FAM \\
FAM & DC & D' \(^{\prime} \neq \varnothing\)
\end{tabular}

Before execution of the subtract unnormalized, long format (SW) instruction, if we assume a value of +1000 in R4, the contents of R4 and main storage area FAM will be:

R4 before execution:


FAM before and after execution:


R4 after execution:


\subsection*{11.45. SUBTRACT UNNORMALIZED, LONG FORMAT (SWR)}


The subtract unnormalized, long format (SWR) instruction causes the contents of the double word in the operand \(2\left(r_{2}\right)\) register to be algebraically subtracted from the double word contents of the operand \(1\left(r_{1}\right)\) register. The difference is placed in the double word operand \(1\left(r_{1}\right)\) register.

Explicit and Implicit Format:
\begin{tabular}{l|l|l} 
LABEL & \(\triangle\) OPERATION \(\Delta\) & \\
\hline [symbol] & SWR & \(r_{1}, r_{2}\) \\
SUB & SWR & R4,R6
\end{tabular}

\section*{Operational Considerations:}
- The execution of the SWR instruction is identical to that of the AWR instruction (11.9), except that the sign is reversed before addition.
- The condition code is set:
- to zero if result fraction is zero;
- to 1 if result fraction is less than zero; and
- to 2 if result fraction is greater than zero.

Code 3 is not used.

\section*{Example:}


Before execution of the subtract unnormalized, long format (SWR) instruction, if we assume values of +1000 in R4 and +900 in R6, the contents of R4 and R6 will be:

R4 before execution:


R6 before and after execution:


R4 after execution:
\begin{tabular}{|l|l|l|l|l|l|l|l|l|l|l|l|l|l|l|l|}
\hline 4 & 3 & 0 & 6 & 4 & 0 & 0 & 0 & 0 & 0 & 0 & 0 & 0 & 0 & 0 & 0 \\
\hline
\end{tabular}

\section*{12. Logical Instructions}

\subsection*{12.1. THE USE OF LOGICAL INSTRUCTIONS}

All operations performed by logical instructions are executed according to the rules of logic. Unlike decimal and fixed-point binary instructions, logical instructions disregard arithmetic signs. Most of these instructions manipulate data bit by bit and operate from left to right.

This section contains the set of logical instructions that are standard. Section 14 contains the set of logical instructions that are featured. If your processor has the control feature, the featured instruction set is available for your use.

\subsection*{12.2. AND (N)}
\begin{tabular}{|c|c|c|c|c|c|c|}
\hline \multicolumn{4}{|c|}{General} & \multicolumn{3}{|r|}{Possible Program Exceptions} \\
\hline \multicolumn{2}{|l|}{OPCODE} & \multirow[t]{2}{*}{FORMAT TYPE} & \multirow[t]{2}{*}{\begin{tabular}{l}
OBJECT INST. \\
LGTH. \\
(BYTES)
\end{tabular}} & \multirow[t]{9}{*}{ADDRESSING
DATA (INVALID SIGN/DIGIT)
DECIMAL DIVIDE
DECIMAL OVERFLOW
EXECUTE
EXPONENT OVERFLOW
EXPONENT UNDERFLOW
FIXED-POINT DIVIDE
FIXED-POINT OVERFLOW
FLOATING-POINT DIVIDE
OPERATION} & \multicolumn{2}{|l|}{\multirow[t]{9}{*}{\begin{tabular}{l}
PROTECTION \\
SIGNIFICANCE \\
SPECIFICATION: \\
NOT A FLOATING-POINT REGISTER \\
OP 1 NOT ON HALFWORD BOUNDARY \\
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
\end{tabular}}} \\
\hline MNEM. & HEX. & & & & & \\
\hline N & 54 & RX & 4 & & & \\
\hline \multicolumn{4}{|c|}{\multirow[b]{2}{*}{Condition Codes}} & & & \\
\hline & & & & & & \\
\hline \multicolumn{4}{|l|}{\multirow[t]{4}{*}{IF RESULT \(=0\), SET TO O IF RESULT \(\neq 0\), SET TO 1 if RESULT \(>0\) O, SET TO 2 IF OVERFLOW, SET TO 3 UNCHANGED}} & & & \\
\hline & & & & & & \\
\hline & & & & & & \\
\hline & & & & & & \\
\hline
\end{tabular}

The and \((\mathrm{N})\) instruction performs a logical AND operation on the contents of the operand 1 register and the contents of the full word in operand 2 . The result is placed in the operand 1 register.

\section*{Explicit Format:}
\begin{tabular}{c|l|l} 
LABEL & \(\triangle\) OPERATION \(\triangle\) & \\
\hline [symbol] & N & \(\mathrm{r}_{1}, \mathrm{~d}_{2}\left(\mathrm{x}_{2}, \mathrm{~b}_{2}\right)\)
\end{tabular}

\section*{Implicit Format:}
\begin{tabular}{c|l|l} 
LABEL & \(\triangle\) OPERATION \(\triangle\) & \\
\hline [symbol] & N & \(\mathrm{r}_{1}, \mathrm{~s}_{2}\left(\mathrm{x}_{2}\right)\)
\end{tabular}

When the \(N\) instruction is executed, a logical AND operation is performed on a bit in operand 1 and a bit in operand 2. The result of the AND operation replaces the bit just accessed in operand 1. This instruction operates from left to right starting with the logical AND operations of bit \(O\) in both operands up to and including the logical AND operation of bit 31 in both operands.

The \(N\) instruction is used to turn off selected bits in the receiving field. The procedure is shown in the following truth table:
\begin{tabular}{|c|c|c|}
\hline Operand 1 & Operand 2 & \begin{tabular}{c} 
Result \\
(Operand 1)
\end{tabular} \\
\hline 0 & 0 & 0 \\
0 & 1 & 0 \\
1 & 0 & 0 \\
1 & 1 & 1 \\
\hline
\end{tabular}

When coding patterns used as operands in AND instructions, code a 0 in all bit positions in operand 2 that correspond to bit positions in operand 1 that you want to set to off ( 0 ), and a 1 in all bit positions in operand 2 that correspond to bit positions in operand 1 that you want to remain the same.

After the N instruction is executed, the condition code is set to 0 if the result is all 0 's; or the condition code is set to 1 if the result is all 1 's or a combination of 1 's and 0 's.

Operational Considerations:
- Any of the general registers (0 through 15) can be used as operand 1.
- Operand 2 must be defined as either a full word or aligned on a full-word boundary.
- The logical AND operation executes upon all 32 bit positions of operands 1 and 2.
- A 0 in a bit position in operand 2 sets its corresponding bit position in operand 1 to 0 .
- A 1 in a bit position in operand 2 allows its corresponding bit position in operand 1 to remain the same.
- The condition code is set accordingly.

Example:
\begin{tabular}{|c|c|c|}
\hline LABEL & \multicolumn{2}{|l|}{\(\triangle\) OPERATION \(\triangle\)} \\
\hline 1 & 10 & 16 \\
\hline & L & 8, HEXVALUE \\
\hline & N & 8,ANDPATRN \\
\hline & - & \\
\hline & - & \\
\hline & - & \\
\hline & DS & \(\emptyset F\) \\
\hline ANDPATRN & DC & \(\chi^{\prime} \emptyset \emptyset \emptyset \emptyset \emptyset \emptyset \mathrm{FF}\) \\
\hline hexvalue & DC & - \({ }^{\prime}\) ¢øFøøø7D' \\
\hline
\end{tabular}

OPERAND

Register 8 before execution of N instruction:
\begin{tabular}{|c|c|c|c|c|c|c|c|}
\hline 0000 & 0000 & 1111 & 0000 & 0000 & 0000 & 0111 & 1101 \\
\hline 0 & 0 & \(F\) & 0 & 0 & 0 & 7 & \(D\) \\
\hline
\end{tabular}\(\quad\)\begin{tabular}{l} 
binary \\
hex
\end{tabular}

ANDPATRN before and after execution of N instruction:
\begin{tabular}{|c|c|c|c|c|c|c|c|}
\hline 0000 & 0000 & 0000 & 0000 & 0000 & 0000 & 1111 & 1111 \\
\hline 0 & 0 & 0 & 0 & 0 & 0 & \(F\) & \(F\) \\
\hline
\end{tabular}

> binary
> hex

Register 8 after execution of N instruction:


In this example, the hexadecimal value in HEXVALUE is loaded into register 8. Then a logical AND operation is performed on the hexadecimal pattern in ANDPATRN (operand 2) and the contents of register 8 . Ones in bit positions 24 through 31 of ANDPATRN allow the corresponding bit positions in register 8 to remain the same. Zeros in bit positions 0 through 23 of ANDPATRN set the corresponding bit positions in register 8 to 0 . Since the high order four bit positions of byte 2 in register 8 are all 1 's, they are set to 0 ; and since the remaining bit positions are already 0 , they remain 0 . The condition code is set to 1 because the result is a combination of 1 's and 0 's.

\subsection*{12.3. AND (NC)}


The and (NC) instruction performs a logical AND operation on the contents of operand 1 and the contents of operand 2 which are both located in main storage. The result is placed in operand 1.

\section*{Explicit Format:}
\begin{tabular}{c|l|l} 
LABEL & \(\triangle\) OPERATION \(\triangle\) & \\
\hline [symbol] & NC & \(\mathrm{d}_{1}\left(\mathrm{l}, \mathrm{b}_{1}\right), \mathrm{d}_{2}\left(\mathrm{~b}_{2}\right)\)
\end{tabular}

\section*{Implicit Format:}
\begin{tabular}{c|l|l} 
LABEL & \(\triangle\) OPERATION \(\triangle\) & \\
\hline [symbol] & NC & \(\mathrm{s}_{1}(\mathrm{I}), \mathrm{s}_{2}\)
\end{tabular}

When the NC instruction is executed, a logical AND operation is performed on a bit in operand 1 and a bit in operand 2. The result of the AND operation replaces the bit accessed in operand 1. This instruction operates from left to right. The length of operand 1 , whether implied or explicit, determines the length of operand 2 . Therefore, when the NC instruction is executed, the lengths of operands 1 and 2 are the same.

The NC instruction is used to turn off selected bits in the receiving field. The procedure is shown in the following truth table:
\begin{tabular}{|c|c|c|}
\hline Operand 1 & Operand 2 & \begin{tabular}{c} 
Result \\
(Operand 1)
\end{tabular} \\
\hline 0 & 0 & 0 \\
0 & 1 & 0 \\
1 & 0 & 0 \\
1 & 1 & 1 \\
\hline
\end{tabular}

When coding patterns used as operands in AND instructions, code a 0 in all bit positions in operand 2 that correspond to bit positions in operand 1 that you want to set to off (0), and a 1 in all bit positions in operand 2 that correspond to bit positions in operand 1 that you want to remain the same.

After the NC instruction is executed, the condition code is set to 0 if the result is all 0 's; or the condition code is set to 1 if the result is all 1 's or a combination of 1 's and 0 's.

Operational Considerations:
- Operands 1 and 2 must be main storage locations.
- The length of operand 1, whether implied or explicit, determines the length of operand 2.
- A 0 in a bit position in operand 2 sets its corresponding bit position in operand 1 to 0 .
- A 1 in a bit position in operand 2 allows its corresponding bit position in operand 1 to remain the same.
- The condition code is set accordingly.
- Operands 1 and 2 can have overlapping bytes.

Example:
\begin{tabular}{|c|c|c|c|}
\hline LABEL & \multicolumn{2}{|l|}{\(\triangle\) OPERATION \(\triangle\)} & \multirow[t]{2}{*}{OPERAND} \\
\hline 1 & 10 & 16 & \\
\hline & NC & LOCATI, LOCAT2 & \\
\hline & - & & \\
\hline & - & & \\
\hline LOCATI & DC & PL2'-217' & \\
\hline LOCAT2 & DC & X'FFFC' & \\
\hline
\end{tabular}

LOCAT1 before execution of NC instruction:
\begin{tabular}{|c|c|c|c|}
\hline 0010 & 0001 & 0111 & 1101 \\
\hline 2 & 1 & 7 & D \\
\hline
\end{tabular}
binary packed decimal

LOCAT2 before and after execution of NC instruction:
\begin{tabular}{|c|c|c|c|}
\hline 1111 & 1111 & 1111 & 1100 \\
\hline\(F\) & \(F\) & \(F\) & \(C\) \\
\hline
\end{tabular}\(\quad\)\begin{tabular}{c} 
binary \\
hex
\end{tabular}

LOCAT1 after execution of NC instruction:


In this example, LOCAT1 is defined as a negative packed decimal number and LOCAT2 is defined as a field containing a hexadecimal value. A logical AND operation is performed on the contents of LOCAT1 and LOCAT2. The result is placed in LOCAT1. The 1's in bit positions 0 through 13 of LOCAT2 allow the corresponding bit positions in LOCAT1 to remain the same. Zeros in bit positions 14 and 15 of LOCAT2 set the corresponding bit positions in LOCAT1 to 0 . Since the low order bit position of LOCAT1 is 1 , it is set to 0 ; and the bit position adjacent to the low order bit position remains 0 , since it is already 0 . The condition code is set to 1 because the result is a combination of 1 's and 0 's. Note the sign value is changed from negative to positive.

NI
12.4. AND (NI)
\begin{tabular}{|c|c|c|c|}
\hline \multicolumn{4}{|c|}{ General } \\
\hline OPCODE & FORMAT & \begin{tabular}{l} 
OBJECT \\
INST. \\
TYPE
\end{tabular} \\
\begin{tabular}{c|c|c|} 
LGTH. \\
(BYTES)
\end{tabular} \\
\hline MNEM. & HEX. & & 4 \\
\hline NI & 94 & SI & 4 \\
\hline
\end{tabular}

Condition Codes
IF RESULT \(=0\), SET TO O
IF RESULT \(\neq 0\), SET TO 1
If result >o, set to 2IF OVERFLOW, SET TO 3
Uunchanged
\begin{tabular}{|c|c|}
\hline \multicolumn{2}{|r|}{Possible Program Exceptions} \\
\hline ADDRESSING & \(\square\) PROTECTION \\
\hline \(\square\) DATA (INVALIDSIGN/DIGIT) & \(\square\) SIGNIFICANCE \\
\hline \(\square\) DECIMAL DIVIDE & \(\square\) SPECIFICATION: \\
\hline \(\square\) DECIMAL OVERFLOW & \(\square\) NOT A FLOATING-POINT REGISTER \\
\hline \(\square\) EXECUTE & \(\square\) OP 1 NOT ON HALF-WORD BOUNDARY \\
\hline \(\square\) EXPONENT OVERFLOW & \(\square\) OP 2 NOT ON HALF-WORD BOUNDARY \\
\hline \(\square\) EXPONENT UNDERFLOW & \(\square\) OP 2 NOT ON FULL-WORD BOUNDARY \\
\hline \(\square\) FIXED-POINT DIVIDE & \(\square\) OP 2 NOT ON DOUBLE-WORD \\
\hline \(\square\) FIXED-POINT OVERFLOW & BOUNDARY \\
\hline \(\square\) FLOATING-POINT DIVIDE & OP 1 NOT EVEN NUMBERED REGISTER \\
\hline \(\square\) OPERATION & op 1 NOT ODD NUMBERED REGISTER NONE \\
\hline
\end{tabular}

The and (NI) instruction performs a logical AND operation on the contents of operand 1 located in main storage and the one byte of immediate data in operand 2. The result is placed in operand 1.

\section*{Explicit Format:}
\begin{tabular}{c|c|cc} 
LABEL & OOPERATION \(\triangle\) & & OPERAND \\
\hline [symbol] & NI & \(\mathrm{d}_{1}\left(\mathrm{~b}_{1}\right), \mathrm{i}_{2}\) &
\end{tabular}

Implicit Format:
\begin{tabular}{c|l|ll} 
LABEL & DOPERATION \(\Delta\) & & OPERAND \\
\hline [symbol] & NI & \(\mathrm{s}_{1}, \mathrm{i}_{2}\) &
\end{tabular}

When the NI instruction is executed, a logical AND operation is performed on a bit in operand 1 and a bit in operand 2. The result of the AND operation replaces the bit just accessed in operand 1 . This instruction operates from left to right. The length of operand 1 can vary but the length of operand 2 is always one byte. Although operands 1 and 2 may have differing lengths, only one byte in operand 1 is used in conjunction with the one byte of immediate data in operand 2 . The result replaces the one byte in operand 1 that was just accessed. If you do not specify the exact byte in operand 1 you want used in the execution with the one byte of data in operand 2, the first byte of operand 1 is used.

The NI instruction is used to turn off selected bits in the receiving field. The procedure is shown in the following truth table:
\begin{tabular}{|c|c|c|}
\hline Operand 1 & Operand 2 & \begin{tabular}{c} 
Result \\
(Operand 1)
\end{tabular} \\
\hline 0 & 0 & 0 \\
0 & 1 & 0 \\
1 & 0 & 0 \\
1 & 1 & 1 \\
\hline
\end{tabular}

When coding patterns used as operands in AND instructions, code a 0 in all bit positions in operand 2 that correspond to bit positions in operand 1 that you want to set to off (0), and a 1 in all bit positions in operand 2 that correspond to bit positions in operand 1 that you want to remain the same.

After the Nl instruction is executed, the condition code is set to 0 if the result is all 0 's, or the condition code is set to 1 if the result is all 1 's or a combination of 1 's and 0 's.

Operational Considerations:
- Operand 1 must be a main storage location.
- Operand 2 must be a 1 -byte, self-defining term.
- The length of operand 1 can vary.
- A 0 in a bit position in operand 2 sets its corresponding bit position in operand 1 to 0 .
- A 1 in a bit position in operand 2 allows its corresponding bit position in operand 1 to remain the same.
- The condition code is set accordingly.
- You can specify the exact byte in operand 1 you want used in the execution with the one byte in operand 2 through relative addressing.

Example:
\begin{tabular}{lll} 
LABEL & OOPERATION \(\triangle\) & OPERAND \\
1 & 10 & 16
\end{tabular}
\begin{tabular}{|c|c|c|}
\hline & HI & RESULT+1, \(\mathrm{B}^{\prime} 1\) ¢øø1め11' \\
\hline & - & \\
\hline & - & \\
\hline RESSULT & DC & BL2'øøбø1111ヵ11ه11øø \\
\hline
\end{tabular}

RESULT before execution of NI instruction:


Operand 2 immediate before and after execution of NI instruction:


RESULT after execution of NI instruction:


In this example, the content of RESULT is a 2-byte binary string of 0's and 1's and the operand 2 immediate is a 1 -byte binary string of 0's and 1 's. A logical AND operation is performed on the contents of the second byte of RESULT and the one byte in operand 2. The result replaces the second byte of RESULT. The 1 's in bit positions 0,4,6, and 7 of the operand 2 immediate allow the corresponding bit positions in the second byte of RESULT to remain the same. Zeros in bit positions 1, 2, 3, and 5 of the operand 2 immediate set the corresponding bit positions in the second byte of RESULT to O. As a result, the second byte of RESULT has been changed from a hexadecimal 6C to a hexadecimal 08.

\subsection*{12.5. AND (NR)}
\begin{tabular}{|c|c|c|c|}
\hline \multicolumn{4}{|c|}{ General } \\
\hline OPCODE & FORMAT & \begin{tabular}{l} 
OBJECT \\
INST. \\
TYPE \\
LGTH. \\
(BYTES)
\end{tabular} \\
\hline MNEM. & HEX. & & \begin{tabular}{c} 
THR
\end{tabular} \\
\hline NR & \(\mathbf{1 4}\) & RR & \(\mathbf{2}\) \\
\hline
\end{tabular}
Condition Codes
\(\square\) IF RESULT \(=0\), SET TO 0
IF RESULT \(<0\), SET TO 1
\(\square\) IF RESULT \(>0\), SET TO 2
\(\square\) IF OVERFLOW, SET TO 3
\(\square\) UNCHANGED
\begin{tabular}{|c|c|}
\hline \multicolumn{2}{|r|}{Possible Program Exceptions} \\
\hline ADDRESSING
DATA (INVALIDSIGN/DIGIT)
DECIMAL DIVIDE
DECIMAL OVERFLOW
EXECUTE
EXPONENT OVERFLOW
EXPONENT UNDERFLOW
FIXED-POINT DIVIDE
FIXED-POINT OVERFLOW
FLOATING-POINT DIVIDE
OPERATION & \begin{tabular}{l}
PROTECTION
SIGNIFICANCE
SPECIFICATION:
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 \\
OP 2 NOT ON DOUBLE-WORD \\
BOUNDARY \\
OP 1 NOT EVEN NUMBERED REGISTER \\
OP 1 NOT ODD NUMBERED REGISTER \\
NONE
\end{tabular} \\
\hline
\end{tabular}

The and (NR) instruction performs a logical AND operation on the contents of the operand 1 and operand 2 registers. The result is placed in the operand 1 register.

Explicit and Implicit Format:
\begin{tabular}{c|c|cc} 
LABEL & \(\triangle\) OPERATION \(\triangle\) & & OPERAND \\
\hline [symbol] & NR & \(r_{1}, r_{2}\) &
\end{tabular}

When the NR instruction is executed, a logical AND operation is performed on a bit in the operand 1 register and a bit in the operand 2 register. The result replaces the bit accessed in operand 1. This instruction operates from left to right starting with the logical AND operation of bit 0 in both registers up to and including the logical AND operation of bit 31 in both registers.

The NR instruction is used to turn off selected bits in the receiving field. The procedure is shown in the following truth table:
\begin{tabular}{|c|c|c|}
\hline Operand 1 & Operand 2 & \begin{tabular}{c} 
Result \\
(Operand 1)
\end{tabular} \\
\hline 0 & 0 & 0 \\
0 & 1 & 0 \\
1 & 0 & 0 \\
1 & 1 & 1 \\
\hline
\end{tabular}

When coding patterns used as operands in AND instructions, code O's in all bit positions in operand 2 that correspond to bit positions in operand 1 that you want to set to off ( 0 ), and a 1 in all bit positions in operand 2 that correspond to bit positions in operand 1 that you want to remain the same.

After the NR instruction is executed, the condition code is set to 0 if the result is all 0 's or the condition code is set to 1 if the result is all 1 's or a combination of 1 's and 0 's.

Operational Considerations:
- Any of the general registers ( 0 through 15 ) can be used as operands 1 and 2 .
- The logical AND operation executes upon all 32 bit positions of the operand 1 and 2 registers.
- A 0 in a bit position in operand 2 sets its corresponding bit position in operand 1 to 0 .
- A 1 in a bit position in operand 2 allows its corresponding bit position in operand 1 to remain the same.
- The condition code is set accordingly.

Example:


Register 5 before execution of NR instruction:


Register 6 before and after execution of NR instruction:


\section*{binary}
hex

Register 5 after execution of NR instruction:


In this example, the LM instruction loads the two consecutive hexadecimal values aligned on a full-word boundary in main storage into registers 5 and 6. Then, a logical AND operation is performed on all 32 bits of registers 5 and 6 . The result replaces register 5 . The 1's in respective bit positions in register 6 allow the corresponding bit positions in register 5 to remain the same. The 0's in the remaining bit positions in register 6 set the corresponding bit positions in register 5 to 0 . In effect, the content of register 5 is completely changed.

\section*{CL}

\subsection*{12.6. COMPARE LOGICAL (CL)}


The compare logical (CL) instruction logically compares the contents of the operand 1 register to the full word in operand 2. The result of the comparison determines the setting of the condition code, bits 34 and 35 of the PSW. (See 8.1.)

Explicit Format:


Implicit Format:
\begin{tabular}{c|l|l} 
LABEL & \(\triangle\) OPERATION \(\triangle\) & \\
\hline [symbol] & CL & \(\mathrm{r}_{1}, \mathrm{~s}_{2}\left(\mathrm{x}_{2}\right)\)
\end{tabular}

Both operands 1 and 2 are considered unsigned binary values with all codes valid. That is, the comparison takes place regardless of data format. This instruction operates from left to right starting with the logical comparison of bit 0 in both operands and ending as soon as an inequality is reached, or the logical comparison of bit 31 in both operands is reached.

After execution of the CL instruction, the condition code is set:
To 0 if operand \(1=\) operand 2
To 1 if operand \(1<\) operand 2
To 2 if operand \(1>\) operand 2

Usually, a conditional branch instruction tests the resulting condition code for an equal to, less than, or greater than condition. If the condition is met, a branch takes place accordingly. If not, the program continues processing as shown in the following coding instruction.

Operational Considerations:
- Any of the general registers (0 through 15) can be used as operand 1.
- Operand 2 must either be defined as a full word or aligned on a full-word boundary.
- Both operands 1 and 2 are considered unsigned binary values.
- The condition code is set accordingly.
- Condition code 3 is not used.
- Operands 1 and 2 remain unchanged after execution of this instruction.

Example:
\begin{tabular}{lll} 
LABEL & \(\triangle\) OPERATION \(\triangle\) & OPERAND \\
1 & 10 & 16
\end{tabular}
\begin{tabular}{lll} 
& SR & 4,4 \\
& L & \(8,=F^{\prime} 75^{\prime}\) \\
& CL & 8, FULVAL \\
& BH & LOOPI \\
& ST & 8, LOW \\
& - & \\
& - & \\
LOOPI & AR & 4,8 \\
& - & \\
& - & \\
FULVAL & DC & \(F^{\prime} 64^{\prime}\) \\
LOW & DS & F
\end{tabular}

Register 5 before and after execution of CL instruction.
\begin{tabular}{|c|c|c|c|c|c|c|c|}
\hline 000010000 & 0000 & 0000 & 0000 & 10000 & 0100 & 1011 \\
\hline 0 & 0 & 0 & 0 & 0 & 0 & 4 & B \\
\hline
\end{tabular}
binary
hex

FULVAL before and after execution of CL instruction:


In this example, register 4 is cleared to 0 and the full-word value coded as a literal is loaded into register 8 . Then the content of register 8 is logically compared to the full-word value in FULVAL. Since the content of register 8 is greater than the content of FULVAL, the condition code is set to 2 and the branch to the instruction labeled LOOP1 takes place. If the result of the comparison was other than a greater than condition, no branch takes place and the ST instruction following the branch instruction is executed.

\subsection*{12.7. COMPARE LOGICAL CHARACTERS (CLC)}

\begin{tabular}{|c|c|}
\hline \multicolumn{2}{|r|}{Possible Program Exceptions} \\
\hline ADDRESSING
DATA (INVALID SIGN/DIGIT)
DECIMAL DIVIDE
DECIMAL OVERFLOW
EXECUTE
EXPONENT OVERFLOW
EXPONENT UNDERFLOW
FIXED-POINT DIVIDE
FIXEDPOINT OVERFLOW
FLOATING-POINT DIVIDE
OPERATION & \begin{tabular}{l}
PROTECTION \\
SIGNIFICANCE \\
SPECIFICATION: \\
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 \\
OP 2 NOT ON DOUBLE-WORD \\
BOUNDARY \\
OP 1 NOT EVEN NUMBERED REGISTER \\
OP 1 NOT ODD NUMBERED REGISTER \\
NONE
\end{tabular} \\
\hline
\end{tabular}

The compare logical characters (CLC) instruction logically compares the contents of operand 1 located in main storage to the contents of operand 2 located in main storage. The result of the comparison determines the setting of the condition code, bits 34 and 35 of the PSW. (See 8.1.)

Explicit Format:
\begin{tabular}{c|l|l} 
LABEL & \(\triangle\) OPERATION \(\triangle\) & \\
\hline Osymbol] & CLC & \(d_{1}\left(1, b_{1}\right), d_{2}\left(b_{2}\right)\)
\end{tabular}

Implicit Format:
\begin{tabular}{c|c|c} 
LABEL & \(\triangle\) OPERATION \(\triangle\) & \\
\hline [symbol] & CLC & \(s_{1}(I), s_{2}\)
\end{tabular}

Both operands 1 and 2 are considered unsigned binary values with all codes valid. That is, the comparison takes place regardless of data format. This instruction operates from left to right starting with the logical comparison of bit 0 in both operands and ending as soon as an inequality is reached (or the end of the field is reached). The length of operand 1 , whether implied or explicit, determines the length of operand 2. Therefore, when the CLC instruction is executed, the length of operands 1 and 2 are the same.

After execution of the CLC instruction, the condition code is set:
To 0 if operand \(1=\) operand 2
To 1 if operand \(1<\) operand 2
To 2 if operand \(1>\) operand 2

Usually, a conditional branch instruction tests the resulting condition code for an equal to, less than, or greater than condition. If the condition is met, a branch takes place accordingly. If not, the program continues processing as shown in the following coding instruction.

Operational Considerations:
- Operands 1 and 2 must be located in main storage.
- Both operands 1 and 2 are considered unsigned binary values.
- The length of operand 1 whether implied or explicit determines the length of operand 2.
- The condition code is set accordingly.
- Operands 1 and 2 remain unchanged after the execution of this instruction.
- Condition code 3 is not used.

Example:
\begin{tabular}{|c|c|c|c|}
\hline LABEL & \multicolumn{2}{|l|}{\(\triangle\) OPERATION \(\triangle\)} & \multirow[t]{2}{*}{OPERAND} \\
\hline 1 & 10 & 16 & \\
\hline & CLC & MONTHI (8) , MONTH2 & \\
\hline & BE & ADRTN & \\
\hline & MVC & MONTHI (8), MONTH2 & \\
\hline & - & & \\
\hline & - & & \\
\hline ADRTN & \(\dot{A P}\) & TOTAL,MTD & \\
\hline & - & & \\
\hline & - & & \\
\hline MONTHI & DC & CL8'NOVEMBER' & \\
\hline MONTH2 & DC & CL8' \({ }^{\prime}\) DECEMBER \({ }^{\prime}\) & \\
\hline TOTAL & DC & PL3'28øø \({ }^{\text {P }}\) & \\
\hline MTD & DC & \(\mathrm{P}^{\prime} 524^{\prime}\) & \\
\hline
\end{tabular}

MONTH1 before and after execution of CLC instruction:
\begin{tabular}{|c|c|c|c|c|c|c|c|}
\hline N & 0 & V & E & M & B & E & R \\
\hline 1101,0101 & 1101,0110 & 111010101 & 110010101 & 110110100 & 110010010 & 1100,0101 & 110111001 \\
\hline D 15 & D 16 & E 15 & C 15 & D 14 & C 12 & C 5 & D 19 \\
\hline
\end{tabular}

MONTH2 before and after execution of CLC instruction:
\begin{tabular}{|c|c|c|c|c|c|c|c|c|c|c|c|c|c|}
\hline D & E & \multicolumn{2}{|l|}{c} & \multicolumn{2}{|r|}{E} & \multicolumn{2}{|l|}{M} & \multicolumn{2}{|r|}{B} & \multicolumn{2}{|l|}{E} & \multicolumn{2}{|l|}{R} \\
\hline 1100, 0100 & 1100,0101 & 11001 & 10011 & 1100 & 10101 & 1101 & 0100 & 1100 & & 11001 & & 1101 & 1001 \\
\hline C 14 & C:5 & C 1 & 3 & C & 5 & D & 4 & & 12 & & 5 & & 9 \\
\hline
\end{tabular}

In this example, the content of MONTH1 is logically compared to the content of MONTH2. Since the content of MONTH1 (its binary value) is greater than the contents of MONTH2, the condition code is set to 2 . The following branch instruction tests for an equal to condition (condition code of 0 ). Because that condition does not exist, no branch is taken, the MVC instruction following the BE branch instruction is executed, and the program continues processing.

\section*{CLI}

\subsection*{12.8. COMPARE LOGICAL IMMEDIATE (CLI)}
\begin{tabular}{|c|c|c|c|c|c|c|}
\hline \multicolumn{4}{|c|}{General} & \multicolumn{3}{|r|}{Possible Program Exceptions} \\
\hline \multicolumn{2}{|l|}{OPCODE} & \multirow[t]{2}{*}{FORMAT TYPE} & \multirow[t]{2}{*}{\begin{tabular}{l}
OBJECT \\
INST. \\
LGTH. \\
(BYTES)
\end{tabular}} & \multirow[t]{5}{*}{ADDRESSING
DATA (INVALID SIGN/DIGIT)
DECIMAL DIVIDE
DECIMAL OVERFLOW
EXECUTE
EXPONENT OVERFLOW
EXPONENT UNDERFLOW
FIXED-POINT DIVIDE
FIXED-POINT OVERFLOW
FLOATING-POINT DIVIDE
OPERATION} & \multicolumn{2}{|l|}{\multirow[t]{5}{*}{\begin{tabular}{l}
PROTECTION \\
SIGNIFICANCE \\
SPECIFICATION: \\
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 \\
OP 2 NOT ON DOUBLE-WORD \\
BOUNDARY \\
OP 1 NOT EVEN NUMBERED REGISTER \\
OP 1 NOT ODD NUMBERED REGISTER \\
NONE
\end{tabular}}} \\
\hline MNEM. & HEX. & & & & & \\
\hline CLI & 95 & SI & 4 & & & \\
\hline \multicolumn{4}{|c|}{Condition Codes} & & & \\
\hline \multicolumn{4}{|l|}{IF OPERAND \(1=i_{2}\), SET TO O IF OPERAND \(1<\mathrm{i}_{2}\), SET TO 1 IF OPERAND \(1>i_{2}\), SET TO 2 IF OVERF LOW, SET TO 3 UNCHANGED} & & & \\
\hline
\end{tabular}

The compare logical immediate (CLI) instruction logically compares the content of operand 1 located in main storage to the 1 -byte immediate data of operand 2. The result of the comparison determines the setting of the condition code, bits 34 and 35 of the PSW. (See 8.1.)

\section*{Explicit Format:}
\begin{tabular}{c|l|l} 
LABEL & \(\triangle\) OPERATION \(\Delta\) & \\
\hline [symbol] & CLI & \(d_{1}\left(b_{1}\right), i_{2}\)
\end{tabular}

Implicit Format:
\begin{tabular}{c|c|cc} 
LABEL & \(\triangle\) OPERATION \(\triangle\) & \\
\hline [symbol] & CLI & \(\mathrm{s}_{1}, \mathrm{i}_{2}\)
\end{tabular}

Both operands 1 and 2 are considered unsigned binary values with all codes valid. That is, the comparison takes place regardless of data format. The length of operand 1 can vary in length but the length of operand 2 is always one byte. Although the lengths of operands 1 and 2 differ, only one byte of operand 1 is compared to the one byte of immediate data in operand 2. If you don't specify the exact byte in operand 1 you want logically compared to the one byte of data in operand 2, the first byte of operand 1 is used. This instruction operates from left to right starting with the logical comparison of bit 0 of the byte specified in operand 1 and bit 0 of operand 2, and ending as soon as an inequality is found, or the logical comparison of bit 7 of the byte specified in operand 1 and operand 2 is reached.

After the execution of the CLI instruction, the condition code is set:
To 0 if operand \(1=\) operand 2
To 1 if operand \(1<\) operand 2
To 2 if operand \(1>\) operand 2
Usually, a conditional branch instruction tests the condition code for an equal to, less than, or greater than condition. If that condition is met, the branch takes place. If not, no branch takes place and the program continues processing as shown in the following coding instruction.

Operational Considerations:
- Operand 1 must be located in main storage.
- Operand 2 must be a 1 -byte, self-defining term.
- You can specify the exact byte in operand 1 you want logically compared to the one byte in operand 2 through relative addressing.
- Operands 1 and 2 remain unchanged after the execution of this instruction.
- The condition code is set accordingly.
- The length of operand 1 can vary.
- Condition code 3 is not used.

Example:
\begin{tabular}{lll} 
LABEL & \(\triangle O P E R A T I O N \triangle\) & OPERAND \\
1 & 10 & 16
\end{tabular}
\begin{tabular}{|c|c|c|}
\hline & CLI & STORAGE+1, X'F7' \\
\hline & BE & EQUALITY \\
\hline & PACK & Storagep (2), Storage (3) \\
\hline & - & \\
\hline & - & \\
\hline EQUALITY & MVC & BUF (1), STORAGE+1 \\
\hline & - & \\
\hline & - & \\
\hline BUF & DC & CL2'ヵ' \\
\hline StORAGE & DC & X'F6F7F2' \\
\hline Storagep & DC & PL2'ø' \\
\hline
\end{tabular}

STORAGE before and after execution of CLI instruction:


Operand 2 immediate before and after execution of CLI instruction:

binary
hex

In this example, the second byte in STORAGE is compared to the 1 -byte immediate data in operand 2. Since the content of the second byte of STORAGE is equal to operand 2, the condition code is set to 0 , and the branch to the instruction labeled EQUALITY takes place. If the result of the comparison is not equal, no branch takes place, the PACK instruction following the branch instruction is executed, and the program continues processing.

Example:
\begin{tabular}{|c|c|c|c|}
\hline \multirow[t]{2}{*}{\[
\frac{\text { LABEL }}{1}
\]} & \multicolumn{2}{|l|}{\(\triangle\) OPERATIONA} & \multirow[t]{2}{*}{OPERAND} \\
\hline & 10 & 16 & \\
\hline & LA & 8,526 & \\
\hline & CLI & AREA,C'T' & \\
\hline & BE & TOOLRTN & \\
\hline & MVI & HOLD,C'T' & \\
\hline & - & & \\
\hline & - & & \\
\hline TOOLRTN & s & \(8,=F^{\prime \prime} 1\) & \\
\hline & - & & \\
\hline & - & & \\
\hline AREA & DC & CL3'T12' & \\
\hline HOLD & DC & CLI' \({ }^{\prime}\) & \\
\hline
\end{tabular}

AREA before and after execution of CLI instruction:


Operand 2 immediate before and after execution of CLI instruction:


In this example, register 8 is loaded with a value of 526 . Then the contents of the first byte of AREA is logically compared to operand 2. Because no one byte is specified in AREA, the first byte is used. Since the content of byte 1 of AREA is equal to the content of operand 2, the condition code is set to 0 , and the branch to the instruction labeled TOOLRTN takes place. If the result of the comparison is not equal, no branch takes place, the MVI instruction following the branch instruction is executed, and the program continues processing.

Example:
\begin{tabular}{|c|c|c|}
\hline \multirow[t]{2}{*}{\[
\begin{aligned}
& \text { LABEL } \\
& 1
\end{aligned}
\]} & \multicolumn{2}{|l|}{\(\triangle O P E R A T I O N \triangle\)} \\
\hline & 10 & 16 \\
\hline & LM & 3,4,LOADREG \\
\hline & CLI & NUMIN, X'Cl' \\
\hline & BE & STOCKNO \\
\hline & MVI & NEWHOLD,NUMIN \\
\hline & - & \\
\hline & - & \\
\hline \multirow[t]{3}{*}{Stockno} & \(\dot{A R}\) & 3,4 \\
\hline & - & \\
\hline & - & \\
\hline NEWHOLD & DC & CLI' ' \\
\hline Numin & DC & CL4'A256' \\
\hline LOADREG & DC & F'5264' \\
\hline & DC & \(F^{\prime \prime}\) \\
\hline
\end{tabular}

NUMIN before and after execution of the CLI instruction:


Operand 2 immediate before and after execution of the CLI instruction:


In this example, two consecutive full words in main storage are loaded into registers 3 and 4. The first byte of NUMIN is logically compared to the 1 -byte immediate in operand 2. Because no one byte is specified in NUMIN, the first byte is moved. Since the content of byte 1 of NUMIN is equal to the content of operand 2, the condition code is set to 0 , and the branch to the instruction labeled STOCKNO takes place. If the result of the comparison is not equal, no branch takes place, the MVI instruction following the branch instruction is executed, and the program continues processing.

\section*{CLR}

\subsection*{12.9. COMPARE LOGICAL (CLR)}


The compare logical (CLR) instruction logically compares the content of the operand 1 register to the content of the operand 2 register. The result of the comparison determines the setting of the condition code, bits 34 and 35 of the PSW. (See 8.1.)

Explicit and Implicit Format:
\begin{tabular}{c|c|c} 
LABEL & \(\triangle\) OPERATION \(\triangle\) & \\
\hline [symbol] & CLR & \(r_{1}, r_{2}\)
\end{tabular}

Both operands 1 and 2 are considered unsigned binary values with all codes valid. That is, the comparison takes place regardless of data format. This instruction operates from left to right starting with the logical comparison of bit 0 in both operands and ending as soon as an inequality is found, or the logical comparison of bit 31 in both operands is reached.

After execution of the CLR instruction, the condition code is set:
To 0 if operand \(1=\) operand 2
To 1 if operand \(1<\) operand 2
To 2 if operand \(1>\) operand 2
Usually, a conditional branch instruction tests the resulting condition code for an equal to, less than, or greater than condition. If the condition is met, a branch takes place accordingly. If not, the program continues processing as shown in the following coding instruction.

Operational Considerations:
- Any of the general registers (0 through 15) can be used as operands 1 and 2.
- Both operands 1 and 2 are considered unsigned binary values.
- The condition code is set accordingly.
- Operands 1 and 2 remain unchanged after the execution of this instruction.
- Condition code 3 is not used.

Example:
\begin{tabular}{|c|c|c|c|}
\hline Label & \multicolumn{2}{|l|}{\(\triangle O P E R A T I O N \triangle\)} & \multirow[t]{2}{*}{OPERAND} \\
\hline 1 & 10 & 16 & \\
\hline & SR & 7.7 & \\
\hline & L & 5, =F'1250' & \\
\hline & A & 7,=F'875' & \\
\hline COMPARE & CR & 5,7 & \\
\hline & BH & ADD2 & \\
\hline & CVD & 7,DBLWD & \\
\hline & B & END & \\
\hline ADD2 & AH &  & \\
\hline & B & COMPARE & \\
\hline END & MVC & BUF, DBLWD+5 & \\
\hline & - & & \\
\hline & - & & \\
\hline DBLWD & DS & D & \\
\hline BUF & DC & PL3'ø & \\
\hline
\end{tabular}

In this example, register 7 is cleared to 0 . A full word containing the decimal value 1250 is loaded into register 5. Another full word containing the decimal value 875 is added to register 7 . Then the content of register 5 is logically compared to the content of register 7. Since the content of register 5 is greater than the content of register 7 , the condition code is set to 2 , and the branch to the instruction labeled ADD2 takes place. There, a half word containing the decimal value 375 is added to register 7 . An unconditonal branch to the instruction labeled COMPARE takes place and registers 5 and 7 are logically compared again. This time, the content of register 5 is equal to the content of register 7 . Since an equal to condition exists, the condition code is set to 0 , and no branch takes place. The CVD instruction following the branch instruction is executed and the program continues processing.

\subsection*{12.10. EXCLUSIVE OR (X)}
\begin{tabular}{|c|c|c|c|c|c|c|}
\hline \multicolumn{4}{|c|}{General} & \multicolumn{3}{|r|}{Possible Program Exceptions} \\
\hline \multicolumn{2}{|l|}{OPCODE} & \multirow[t]{2}{*}{FORMAT TYPE} & \multirow[t]{2}{*}{\begin{tabular}{l}
OBJECT \\
INST. \\
LGTH. \\
(BYTES)
\end{tabular}} & \multirow[t]{9}{*}{\begin{tabular}{l}
ADDRESSING \\
DATA (INVALIDSIGN/DIGIT) \\
DECIMAL DIVIDE \\
DECIMAL OVERFLOW \\
EXECUTE \\
EXPONENT OVERFLOW \\
EXPONENT UNDERFLOW \\
FIXED-POINT DIVIDE \\
FIXED-POINT OVERFLOW \\
FLOATING-POINT DIVIDE \\
OPERATION
\end{tabular}} & \multicolumn{2}{|l|}{\multirow[t]{9}{*}{\begin{tabular}{l}
PROTECTION
SIGNIFICANCE
SPECIFICATION:
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 \\
OP 2 NOT ON DOUBLEWORD \\
BOUNDARY \\
OP 1 NOT EVEN NUMBERED REGISTER \\
OP 1 NOT ODD NUMBERED REGISTER \\
NONE
\end{tabular}}} \\
\hline MNEM. & HEX. & & & & & \\
\hline X & 57 & RX & 4 & & & \\
\hline & & & & & & \\
\hline \multicolumn{4}{|c|}{Condition Codes} & & & \\
\hline \multicolumn{4}{|l|}{\multirow[t]{4}{*}{IF RESULT \(=0\), SET TO 0 IF RESULT \(\neq 0\), SET TO 1 IF RESULT \(>0\) O, SET TO 2 IF OVERFLOW, SET TO 3 UNCHANGED}} & & & \\
\hline & & & & & & \\
\hline & & & & & & \\
\hline & & & & & & \\
\hline
\end{tabular}

The exclusive or \((\mathrm{X})\) instruction performs an exclusive OR operation on the content of the operand 1 register and the full word in operand 2 . The result is placed in operand 1 and also determines the setting of the condition code, bits 34 and 35 of the PSW. (See 8.1.)

\section*{Explicit Format:}
\begin{tabular}{c|l|l} 
LABEL & ДOPERATION \(\triangle\) & \\
\hline [symbol] & X & \(\mathrm{r}_{1}, \mathrm{~d}_{2}\left(\mathrm{x}_{2}, \mathrm{~b}_{2}\right)\)
\end{tabular}

Implicit Format:


When the \(X\) instruction is executed, an exclusive OR operation is performed on a bit in operand 1 and a bit in operand 2. The result of the exclusive OR operation replaces the bit just accessed in operand 1. This instruction operates from left to right starting with the exclusive OR operation of bit 0 in both operands up to and including the exclusive OR operation of bit 31 in both operands.

The \(X\) instruction is used to modify bits in the receiving field. The procedure is shown in the following truth table:
\begin{tabular}{|c|c|c|}
\hline Operand 1 & Operand 2 & \begin{tabular}{c} 
Result \\
(Operand 1)
\end{tabular} \\
\hline 0 & 0 & 0 \\
1 & 0 & 1 \\
0 & 1 & 1 \\
1 & 1 & 0 \\
\hline
\end{tabular}

When coding patterns used as operands in exclusive OR instructions, the following codes are set:
- 0 in all bit positions in operand 2 that correspond to bit positions in operand 1 that you want to remain the same.
- 1 in all bit positions in operand 2 that correspond to bit positions containing 0's in operand 1 that you want set to 1 .
- 1 in all bit positions in operand 2 that correspond to bit positions containing 1 's in operand 1 that you want set to 0 .

After the X instruction is executed, the condition code is set as follows:
To 0 if result is all 0 's.
To 1 if result is a combination of 1's and 0's.
Operational Considerations:
- Any of the general registers (0 through 15) can be used as operand 1.
- Operand 2 must be either defined as a full word or aligned on a full-word boundary.
- The condition code is set accordingly.
- Condition code 2 and 3 are not used.

Example：
\begin{tabular}{|c|c|c|c|}
\hline \multirow[t]{2}{*}{LABEL} & \multicolumn{2}{|l|}{\(\triangle\) OPERATION \(\triangle\)} & \multirow[t]{2}{*}{OPERAND} \\
\hline & 10 & 16 & \\
\hline & L & 6，VAL & \\
\hline & X & 6，XPATTERN & \\
\hline & － & & \\
\hline & － & & \\
\hline & DS & øF & \\
\hline VAL & DC & メ＇øøøøCAF2＇ & \\
\hline XPATTERN & DC & －＇øのøøС5め口＇ & \\
\hline
\end{tabular}

Register 6 before execution of \(X\) instruction：

binary
hex

XPATTERN before and after execution of \(X\) instruction：

binary
hex

Register 6 after execution of \(X\) instruction：


In this example，the content of VAL is loaded into register 6．Then the exclusive OR operation is performed on the contents of register 6 and the contents of XPATTERN．The resultant modified binary string is placed in register 6 ．Since the result is a combination of 0 ＇s and 1 ＇s，the condition code is set to 1.

\section*{xC}

\subsection*{12.11. EXCLUSIVE OR (XC)}


The exclusive or (XC) instruction performs an exclusive OR operation on the contents of operand 1 and operand 2, both located in main storage. The result is placed in operand 1 and also determines the setting of the condition code, bits 34 and 35 of the PSW. (See 8.1.)

Explicit Format:
\begin{tabular}{c|c|l} 
LABEL & \(\triangle\) OPERATION \(\triangle\) & \\
\hline [symbol] & XC & \(\mathrm{d}_{1}\left(\mathrm{l}, \mathrm{b}_{1}\right), \mathrm{d}_{2}\left(\mathrm{~b}_{2}\right)\)
\end{tabular}

Implicit Format:
\begin{tabular}{c|c|c} 
Label & \(\triangle\) operation \(\triangle\) & \\
\hline [symbol] & XC & \(\mathrm{s}_{1}(\mathrm{I}), \mathrm{s}_{\mathbf{2}}\)
\end{tabular}

When the XC instruction is executed, an exclusive OR operation is performed on a bit in operand 1 and a bit in operand 2. The result of the exclusive OR operation replaces the bit accessed in operand 1. This instruction operates from left to right. The length of operand 1 , whether implied or explicit, determines the length of operand 2. Therefore, when the XC instruction is executed, the lengths of operands 1 and 2 are the same.

The XC instruction is used to modify bits in the receiving field．The procedure is shown in the following truth table：
\begin{tabular}{|c|c|c|}
\hline Operand 1 & Operand 2 & \begin{tabular}{c} 
Result \\
（Operand 1）
\end{tabular} \\
\hline 0 & 0 & 0 \\
1 & 0 & 1 \\
0 & 1 & 1 \\
1 & 1 & 0 \\
\hline
\end{tabular}

When coding patterns used as operands in exclusive OR instructions，the following codes are set：
－ 0 in all bit positions in operand 2 that correspond to bit positions in operand 1 that you want to remain the same．
－ 1 in all bit positions in operand 2 that correspond to bit positions containing 0 ＇s in operand 1 that you want set to 1 ．
－ 1 in all bit positions in operand 2 that correspond to bit positions containing 1 ＇s in operand 1 that you want set to 0 ．

After the XC instruction is executed，the condition code is set as follows：
To 0 if result is all 0 ＇s．
To 1 if result is a combination of 1 ＇s and 0＇s．
Operational Considerations：
－Operands 1 and 2 must be located in main storage．
－The condition code is set accordingly．
－Operands 1 and 2 can have overlapping bytes．
Example：
\begin{tabular}{|c|c|c|}
\hline \multirow[t]{2}{*}{\begin{tabular}{l}
LABEL \\
1
\end{tabular}} & \multicolumn{2}{|l|}{\(\triangle\) OPERATION \(\triangle\)} \\
\hline & 10 & 16 \\
\hline & XC & A，B \\
\hline & XC & B，A \\
\hline & － & \\
\hline & － & \\
\hline A & DC & BLI＇øøø11め11＇ \\
\hline B & DC & BLI＇øめø1めøø1＇ \\
\hline
\end{tabular}

A before execution of first XC instruction:

binary
hex
\(B\) before and after execution of first \(X C\) instruction:


A after execution of first XC instruction:

binary
hex

B before execution of second XC instruction:


A before and after execution of second XC instruction:

\(B\) after execution of second XC instruction:

binary
hex

In this example, the exclusive OR operation is performed on the contents of \(A\) and \(B\). The resultant modified binary string of 1's and O's is placed in A. Then another exclusive OR operation is performed on the contents of \(B\) and \(A\) (now modified). That resultant modified binary string of 1 's and 0 's is placed in \(B\). Note that the sequence of executions of the exclusive OR operation on \(A\) and \(B\), then \(B\) and \(A\) results in \(A\) containing the resultant modified binary string and \(B\) containing the original contents of \(A\). Note that the original contents of \(A\) is saved without use of another area in main storage.

\section*{XI}

\subsection*{12.12. EXCLUSIVE OR (XI)}
\begin{tabular}{|c|c|c|c|c|c|c|}
\hline \multicolumn{4}{|c|}{General} & \multicolumn{3}{|r|}{Possible Program Exceptions} \\
\hline \multicolumn{2}{|l|}{opcode} & \multirow[t]{2}{*}{FORMAT TYPE} & \multirow[t]{2}{*}{OBJECT INST. LGTH. (BYTES)} & \multirow[t]{5}{*}{\begin{tabular}{l}
ADDRESSING \\
data (invalid sign/digit)
decimal divide
decimal overflow
execute
EXPONENT OVERFLOW
EXPONENT UNDERFLOW
FIXED-POINT DIVIDE
FIXED-POINT OVERFLOW
floating-point divide
operation
\end{tabular}} & \multicolumn{2}{|l|}{\multirow[t]{5}{*}{\begin{tabular}{l}
PROTECTION
SIGNIFICANCE
specification: \\
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 OP 2 NOT ON DOUBLE-WORD BOUNDARY \\
OP 1 NOT EVEN NUMBERED REGISTER op 1 NOT ODD NUMBERED REGISTER NONE
\end{tabular}}} \\
\hline MNEM. & HEX. & & & & & \\
\hline XI & 97 & SI & 4 & & & \\
\hline \multicolumn{4}{|c|}{Condition Codes} & & & \\
\hline \multicolumn{4}{|l|}{BIF RESULT = o, SET TO O
IF RESULT \(\neq 0\), SET TO 1
IF RESULT \(>0\), SET TO 2
IFOVERFLOW, SET TO 3
UNCHANGED} & & & \\
\hline
\end{tabular}

The exclusive or ( XI ) instruction performs an exclusive OR operation on the contents of one byte of operand 1 located in main storage and the one byte of immediate data in operand 2. The result is placed in operand 1 and also determines the setting of the condition code, bits 34 and 35 of the PSW. (See 8.1.)

\section*{Explicit Format:}
\begin{tabular}{c|l|ll} 
LABEL & \(\triangle\) OPERATION \(\triangle\) & & OPERAND \\
\hline [symbol] & XI & \(\mathrm{d}_{1}\left(\mathrm{~b}_{1}\right), \mathrm{i}_{2}\)
\end{tabular}

Implicit Format:
\begin{tabular}{c|l|l} 
LABEL & \(\triangle\) OPERATION \(\triangle\) & \\
\hline [symbol] & XI & \(\mathrm{s}_{1}, \mathrm{i}_{2}\)
\end{tabular}

When the XI instruction is executed, an exclusive OR operation is performed on a bit in operand 1 and a bit in operand 2 . The result of the exclusive OR operation replaces the bit accessed in operand 1. This instruction operates from left to right. The length of operand 1 can vary but the length of operand 2 is always one byte. Although operands 1 and 2 may have differing lengths, only one byte in operand 1 is used in the exclusive OR operation. The result replaces the one byte in operand 1 that was accessed. If you do not specify the exact byte in operand 1 you want used in the exclusive OR operation, the first byte of operand 1 is used.

The XI instruction is used to modify bits in the receiving field. The procedure is shown in the following truth table:
\begin{tabular}{|c|c|c|}
\hline Operand 1 & Operand 2 & \begin{tabular}{c} 
Result \\
(Operand 1)
\end{tabular} \\
\hline 0 & 0 & 0 \\
1 & 0 & 1 \\
0 & 1 & 1 \\
1 & 1 & 0 \\
\hline
\end{tabular}

When coding patterns are used as operands in exclusive OR instructions, the following codes are set:
- 0 in all bit positions in operand 2 that correspond to bit positions in operand 1 that you want to remain the same.
- 1 in all bit positions in operand 2 that correspond to bit positions containing 0 's in operand 1 that you want set to 1 .
- 1 in all bit positions in operand 2 that correspond to bit positions containing 1 's in operand 1 that you want set to 0 .

After the XI instruction is executed, the condition code is set as follows:
To 0 if result is all 0 's.
To 1 if result is a combination of 1 's and 0's.
Operational Considerations:
- Operand 1 must be a main storage location.
- Operand 2 must be a 1 -byte self-defining term.
- The length of operand 1 can vary.
- The condition code is set accordingly.
- You can specify the exact byte in operand 1 you want used with the one byte in operand 2 through relative addressing.

Example:
\begin{tabular}{lll} 
LABEL & \(\triangle\) OPERATION \(\triangle\) & OPERAND \\
10 & 10 &
\end{tabular}
\begin{tabular}{|c|c|c|}
\hline & CLC & ITEMNO (1), STNDNO \\
\hline & BE & SWTCHON \\
\hline & - & \\
\hline & - & \\
\hline SWTCHON & \(\dot{X I}_{1}\) & 1 TEMNO+1, 'ø1' \\
\hline & MVC & PROCESS, ITEMNO \\
\hline & - & \\
\hline & - & \\
\hline 1 TEMNO & DC & X'F2øめ' \\
\hline STNDNO & DC & X'F2' \\
\hline PROCESS & DS & CL2 \\
\hline
\end{tabular}

ITEMNO before execution of XI instruction:


Operand 2 immediate before and after execution of XI instruction:


ITEMNO after execution of XI instruction:


In this example, the first byte of ITEMNO is logically compared to the content of STNDNO. Since they compare equally, the condition code is set to 0 and the branch to the instruction labeled SWTCHON takes place. There, the exclusive OR operation is performed on the first byte of ITEMNO and the one byte of data in operand 2. The result replaces the first byte in ITEMNO. The only change to the content of ITEMNO is the setting of the low order bit. This is an example of how the XI instruction can be used in setting programmed binary bit switches that are useful in testing for existing conditions within the logic of the program.

\section*{XR}

\subsection*{12.13. EXCLUSIVE OR (XR)}


The exclusive or (XR) instruction performs an exclusive OR operation on the contents of the operand 1 register and operand 2 register. The result is placed in the operand 1 register and also determines the setting of the condition code, bits 34 and 35 of the PSW. (See 8.1.)

Explicit and Implicit Format:


When the XR instruction is executed, an exclusive OR operation is performed on a bit in the operands of 1 and 2 registers. The result of the exclusive OR operation replaces the bit just accessed in operand 1. This instruction operates from left to right starting with the execution of the exclusive OR operation on bit 0 in both registers up to and including bit 31 in both registers.

The XR instruction is used to modify bits in the receiving field. The procedure is shown in the following truth table:
\begin{tabular}{|c|c|c|}
\hline Operand 1 & Operand 2 & \begin{tabular}{c} 
Result \\
(Operand 1)
\end{tabular} \\
\hline 0 & 0 & 0 \\
1 & 0 & 1 \\
0 & 1 & 1 \\
1 & 1 & 0 \\
\hline
\end{tabular}

When coding patterns are used as operands in exclusive OR instructions, the following codes are set:
- 0 in all bit positions in operand 2 that correspond to bit positions in operand 1 that you want to remain the same.
- 1 in all bit positions in operand 2 that correspond to bit positions containing 0 's in operand 1 that you want set to 1 .
- 1 in all bit positions in operand 2 that correspond to bit positions containing 1 's in operand 1 that you want set to 0 .

After the XR instruction is executed, the condition code is set as follows:
To 0 if result is all 0 's.
To 1 if result is a combination of 1 's and 0 's.

\section*{Operational Considerations:}
- Any of the general registers (0 through 15 ) can be used as operands 1 and 2.
- The condition code is set accordingly.

\section*{Example:}
\begin{tabular}{|c|c|c|c|}
\hline LABEL & \multicolumn{2}{|l|}{\(\triangle\) OPERATION \(\triangle\)} & OPERAND \\
\hline L & 10 & 16 & \\
\hline & SR & 4,4 & \\
\hline & L & 7,CONTENTS & \\
\hline & A & 7, =F'25' & \\
\hline & CVD & 7,DBLWD & \\
\hline & MVC & AREA, DBLWD+5 & \\
\hline & XR & 7,7 & \\
\hline & - & & \\
\hline & - & & \\
\hline CONTENTS & DC & \(F^{\prime} 50^{\prime}\) & \\
\hline & - & & \\
\hline & - & & \\
\hline DBL.WD & DS & D & \\
\hline AREA & DS & PL3 & \\
\hline
\end{tabular}

Register 7 before execution of XR instruction:

binary
hex

Register 7 after execution of XR instruction:

binary
hex

In this example, the full word in CONTENTS is loaded into register 7. A full word containing the decimal value of 25 is added to register 7, and that result is converted into its decimal equivalent and placed in DBLWD in main storage. Then the content of the last three bytes of DBLWD are moved into a smaller field, and the exclusive OR operation is performed on the contents of register 7 and itself. The result is a field of 0's. This is another method of clearing a field to 0's.

\subsection*{12.14. INSERT CHARACTER (IC)}
\begin{tabular}{|c|c|c|c|c|c|c|}
\hline \multicolumn{4}{|c|}{General} & \multicolumn{3}{|r|}{Possible Program Exceptions} \\
\hline \multicolumn{2}{|l|}{OPCODE} & \multirow[t]{2}{*}{FORMAT TYPE} & \multirow[t]{2}{*}{\begin{tabular}{l}
OBJECT \\
INST. \\
LGTH. \\
(BYTES)
\end{tabular}} & \multirow[t]{5}{*}{ADDRESSING
DATA (INVALID SIGN/DIGIT)
DECIMAL DIVIDE
DECIMAL OVERFLOW
EXECUTE
EXPONENT OVERFLOW
EXPONENT UNDERFLOW
FIXED-POINT DIVIDE
FIXED-POINT OVERFLOW
FLOATING-POINT DIVIDE
OPERATION} & \multicolumn{2}{|l|}{\multirow[t]{5}{*}{\begin{tabular}{l}
PROTECTION \\
SIGNIFICANCE \\
SPECIFICATION: \\
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 \\
OP 2 NOT ON DOUBLE-WORD \\
BOUNDARY \\
OP 1 NOT EVEN NUMBERED REGISTER \\
OP 1 NOT ODD NUMBERED REGISTER \\
NONE
\end{tabular}}} \\
\hline MNEM. & HEX. & & & & & \\
\hline IC & 43 & RX & 4 & & & \\
\hline \multicolumn{4}{|c|}{Condition Codes} & & & \\
\hline \multicolumn{4}{|l|}{IF RESULT \(=0\), SET TO O
IF RESULT \(<0\), SET TO 1
IF RESULT \(>0\), SET TO 2
IF OVERFLOW, SET TO 3 UNCHANGED} & & & \\
\hline
\end{tabular}

The insert character (IC) instruction places one byte of data from operand 2 into the rightmost byte of the operand 1 register.

\section*{Explicit Format:}
\begin{tabular}{c|l|l} 
LABEL & \(\triangle\) OPERATION \(\Delta\) & \\
\hline [symbol] & IC & \(\mathrm{r}_{1}, \mathrm{~d}_{2}\left(\mathrm{x}_{2}, \mathrm{~b}_{2}\right)\)
\end{tabular}

Implicit Format:
\begin{tabular}{c|l|l} 
LABEL & \(\triangle\) OPERATION \(\triangle\) & \\
\hline [symbol] & IC & \(r_{1}, s_{2}\left(x_{2}\right)\)
\end{tabular}

The data in operand 2 can be defined in any format. The length of operand 2 can vary but the length of operand 1 is always four bytes. Although operands 1 and 2 can have differing or equal lengths, only one byte of operand 2 is inserted into the rightmost byte of the operand 1 register. The remaining three bytes of operand 1 remain the same. If you do not specify the exact byte in operand 2 you want inserted into operand 1, the first byte of operand 2 is used.

\section*{Operational Considerations:}
- Any of the general registers ( 0 through 15 ) can be used as operand 1.
- The length of operand 2 can vary.
- You can specify the exact byte in operand 2 you want inserted into the rightmost byte of operand 1 through relative addressing.
- The condition code remains unchanged.

\section*{Example:}


Register 4 before execution of IC instruction:


NEWVAL before and after execution of IC instruction:


In this example, the content of HEXVAL is loaded into register 4. Then the fourth byte of HEXVAL is logically compared to the one byte in NEWVAL. Since the content of HEXVAL +3 is greater than NEWVAL, the condition code is set to 2 and the branch to the instruction labeled INSERT takes place because a not equal to condition exists. There, the 1 -byte field in NEWVAL is inserted into the rightmost byte of register 4.

\subsection*{12.15. LOAD ADDRESS (LA)}
\begin{tabular}{|c|c|c|c|}
\hline \multicolumn{4}{|c|}{General} \\
\hline \multicolumn{2}{|l|}{opcode} & \multirow{2}{*}{FORMAT
TYPE} & \multirow[t]{2}{*}{object INST. LGTH (BYTES} \\
\hline MNEM. & Hex. & & \\
\hline LA & 41 & RX & 4 \\
\hline \multicolumn{4}{|c|}{Condition Codes} \\
\hline \multicolumn{4}{|l|}{IF RESULT \(=0\), SET TO 0
if RESULT \(<0\), SET TO 1
if Result \(>0\) o, Set to 2
if overflow, set to 3 unchanged} \\
\hline
\end{tabular}
\begin{tabular}{|c|c|}
\hline \multicolumn{2}{|r|}{Possible Program Exceptions} \\
\hline ADDRESSING
DATA (INVALIDSIGN/DIGIT)
DECIMAL DIVIDE
DECIMAL OVERFLOW
EXECUTE
EXPONENT OVERFLOW
EXPONENT UNDERFLOW
FIXED-POINT DIVIDE
FIXED-POINT OVERFLOW
FLOATING-POINT DIVIDE
OPERATION & PROTECTION
SIGNIFICANCE
SPECIFICATION:
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 OP 2 NOT ON DOUBLE-WORD BOUNDARY OP 1 NOT EVEN NUMBERED REGISTER OP 1 NOT ODD NUMBERED REGISTER NONE \\
\hline
\end{tabular}

The load address (LA) instruction places the address of the main storage location of operand 2 into bit positions 8 through 31 (rightmost 3 bytes) of the operand 1 register. Bits 0 through 7 (leftmost byte) of the operand 1 register are set to 0 's.

Explicit Format:
\begin{tabular}{c|l|l} 
LABEL & \(\triangle\) OPERATION \(\triangle\) & \\
\hline [symbol] & LA & \(r_{1}, d_{2}\left(x_{2}, b_{2}\right)\)
\end{tabular}

\section*{Implicit Format:}
\begin{tabular}{c|c|c} 
LABEL & \(\triangle\) OPERATION \(\Delta\) & \\
\hline [symbol] & LA & \(\mathrm{r}_{1}, \mathrm{~s}_{\mathbf{2}}\)
\end{tabular}

Operand 2 can be any byte in main storage and does not have to be aligned on a full-word boundary. Operand 2 can also be a self-defining term. The three rightmost bytes of operand 1 are filled and the leftmost byte of operand 1 is set to 0 's.

\section*{Operational Considerations:}
- Any of the general registers ( 0 through 15 ) can be used as operand 1.
- Any of the general registers (1 through 15) can be used as operand 2. These registers are used as self-defining terms.
- Operand 2 can be any label in main storage.

Example:
\begin{tabular}{|c|c|c|c|}
\hline LABEL & \multicolumn{2}{|l|}{\(\triangle O P E R A T I O N \triangle\)} & \multirow[t]{2}{*}{OPERAND} \\
\hline 1 & 10 & 16 & \\
\hline & SR & 4,4 & \\
\hline & LA & 6,CARDIN+38 & \\
\hline & ZAP & WKLYHRS \(=\) = ' \(\emptyset\) ' & \\
\hline ADDLOOP & PACK & \(\emptyset(3,6), \varnothing(3,6)\) & \\
\hline & AP & WKLYHRS, \(\varnothing(3,6)\) & \\
\hline & A & 4,CONI & \\
\hline & A & 6,CON3 & \\
\hline & C & 4,CON7 & \\
\hline & BL & ADDLOOP & \\
\hline & - & & \\
\hline & . & & \\
\hline CARDIN & DS & CL8ø & \\
\hline WKLYHRS & DS & PL3 & \\
\hline CONI & DC & \(\mathrm{F}^{\prime \prime} 1\) & \\
\hline CON3 & DC & \(F^{\prime} 3^{\prime}\) & \\
\hline CON7 & DC & \(F^{\prime \prime}\) & \\
\hline
\end{tabular}

In this example, register 4 is cleared to 0 . Then the LA instruction loads the address of CARDIN +38 into register 6. The ZAP instruction sets the field labeled WKLYHRS to a packed field of 0 's. Since the address of the byte located at card column 39 is in register 6, the PACK instruction packs the 3-byte field (defined in explicit format) into itself. Note that there is a displacement value of 0 . Therefore, the base address is not modified through displacement values. The 3-byte packed field is now added to WKLYHRS which will eventually contain the total number of hours an employee works in one week. A full word containing the decimal value of one is added to register 4 each time a 3 -byte field is packed and added to WKLYHRS. Register 4 acts as a counter to keep track of the number of times the ADDLOOP routine has been executed. A full word containing the decimal value of three is added to register 6 modifying the address by increasing it three bytes each time the \(A\) instruction is executed. This allows the successive fields on the input card to be processed. Then the content of register 4 is compared to the decimal value of 7 in CON7. The branch if low (BL) instruction tests the condition code for a less than condition. Since the content of register 4 is less than the content of CON7, a branch to the instruction labeled ADDLOOP takes place. The ADDLOOP routine is executed seven times. After the seventh execution, the content of register 4 is not less than CON7 and the instruction following the BL instruction is executed.
12.16. MOVE IMMEDIATE (MVI)
\begin{tabular}{|c|c|c|c|c|c|c|}
\hline \multicolumn{4}{|c|}{General} & \multicolumn{3}{|r|}{Possible Program Exceptions} \\
\hline \multicolumn{2}{|l|}{OPCODE} & \multirow[t]{2}{*}{FORMAT TYPE} & \multirow[t]{2}{*}{\begin{tabular}{l}
OBJECT \\
INST. \\
LGTH. \\
(BYTES)
\end{tabular}} & \multirow[t]{5}{*}{ADDRESSING
DATA (INVALIDSIGN/DIGIT)
DECIMAL DIVIDE
DECIMAL OVERFLOW
EXECUTE
EXPONENT OVERFLOW
EXPONENT UNDERFLOW
FIXED-POINT DIVIDE
FIXED-POINT OVERFLOW
FLOATING-POINT DIVIDE
OPERATION} & \multicolumn{2}{|l|}{\multirow[t]{5}{*}{\begin{tabular}{l}
PROTECTION
SIGNIFICANCE
SPECIFICATION:
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 \\
OP 2 NOT ON DOUBLE-WORD \\
BOUNDARY \\
OP 1 NOT EVEN NUMBERED REGISTER \\
OP 1 NOT ODD NUMBERED REGISTER \\
NONE
\end{tabular}}} \\
\hline MNEM. & HEX. & & & & & \\
\hline MVI & 92 & SI & 4 & & & \\
\hline \multicolumn{4}{|c|}{Condition Codes} & & & \\
\hline \multicolumn{4}{|l|}{IF RESULT \(=0\), SET TO O IF RESULT < O, SET TO 1 IF RESULT \(>0\) O, SET TO 2 IF OVERFLOW, SET TO 3 UNCHANGED} & & & \\
\hline
\end{tabular}

The move immediate ( MVI ) instruction places the one byte of immediate data in operand 2 into one byte of operand 1 located in main storage.

Explicit Format:
\begin{tabular}{c|c|l} 
LABEL & \(\triangle\) OPERATION \(\triangle\) & \\
\hline [symbol] & MVI & \(\mathrm{d}_{1}\left(\mathrm{~b}_{1}\right), \mathrm{i}_{2}\)
\end{tabular}

Implicit Format:
\begin{tabular}{c|c|cc} 
LABEL & \(\triangle\) OPERATION \(\triangle\) & & OPERAND \\
\hline [symbol] & MVI & \(\mathrm{s}_{1}, \mathrm{i}_{2}\) &
\end{tabular}

The data in operands 1 and 2 can be defined in any format. The length of operand 1 can vary but the length of operand 2 is always one byte. Although operands 1 and 2 can have differing lengths, only one byte in operand 1 receives the immediate data from operand 2. If you do not specify the exact byte in operand 1 you want to receive the operand 2 data, the first byte of operand 1 is used.

\section*{Operational Considerations:}
- Operand 1 must be a main storage location.
- Operand 2 must be a 1 -byte, self-defining term.
- The length of operand 1 can vary.
- You can specify the exact byte in operand 1 you want to receive the immediate data in operand 2 by relative addressing.

Example:
LABEL \(\triangle\) OPERATION \(\triangle\)
1016
OPERAND
\begin{tabular}{ll} 
MVI & OUTPUT, X'4 4 ' \\
MVC & OUTPUT \(+1(7)\), OUTPUT \\
\(\bullet\) & \\
OUTPUT & \\
DS & CL8 8
\end{tabular}

OUTPUT before execution of MVI instruction:

leftover data from previous program

Operand 2 immediate before and after execution of MVI instruction:


OUTPUT after execution of MVI instruction:

binary hex

OUTPUT after execution of MVC instruction:
\begin{tabular}{|c|c|c|c|c|c|c|c|c|c|c|c|c|c|c|c|}
\hline 0100 & 0000 & 0100 & 0000 & 0100 & 10000 & 0100 & 10000 & 0100 & 0000 & 0100 & ,0000 & 0100 & 0000 & 0100 & 10000 \\
\hline 41 & 0 & 4 & 0 & 4 & 0 & 41 & 0 & 4 & 0 & & 10 & 4 & 0 & & 0 \\
\hline
\end{tabular}
binary hex

In this example, the one byte of immediate data in operand 2 is placed in the first byte of OUTPUT since no exact byte is specified. Then that first byte of OUTPUT is propagated through that entire field. The length attribute (in this example, 7) can be either implied or explicit and determines the number of bytes that the first byte is propagated through.

\subsection*{12.17. OR (O)}
\begin{tabular}{|c|c|c|c|c|c|}
\hline \multicolumn{4}{|c|}{General} & \multicolumn{2}{|r|}{Possible Program Exceptions} \\
\hline \multicolumn{2}{|l|}{opcode} & \multirow[t]{2}{*}{format TYPE} & \multirow[t]{2}{*}{OBJECT INST. LGTH. (BYTES)} & \multirow[t]{5}{*}{addressing
DATA (INVALID SIGN/DIGIT)
decimal divide
decimal overflow
execute
EXPONENT OVERFLOW
exponent underflow
fixed.point divide
FIXED-POINT OVERFLOW
FLOATING-POINT DIVIDE
operation} & \multirow[t]{2}{*}{PROTECTION
significance
SPECIFICATION:} \\
\hline MNEM. & HEX. & & & & \\
\hline 0 & 56 & RX & 4 & & NOT A FLOATING-POINT REGISTER \\
\hline \multicolumn{4}{|c|}{Condition Codes} & & \(\square\) OP 2 NOT ON HALF-WORD BOUNDARY OP 2 NOT ON FULL-WORD BOUNDARY \\
\hline \multicolumn{4}{|l|}{IF RESULT = O, SET TO 0 IF RESULT \(\neq 0\), SET TO 1 IF RESULT \(>0\), SET TO 2 If overflow, set to 3 unchanged} & & \begin{tabular}{l}
op 2 NOT ON DOUBLE-WORD BOUNDARY \\
OP 1 NOT EVEN NUMBERED REGISTER \\
op 1 NOT ODD NUMBERED REGISTER \\
NONE
\end{tabular} \\
\hline
\end{tabular}

The or ( O ) instruction performs a logical OR operation (sometimes referred to as an inclusive OR operation) on the contents of the operand 1 register and the full word in operand 2. The result is placed in the operand 1 register.

\section*{Explicit Format:}
\begin{tabular}{l|l|l} 
LABEL & \(\triangle\) OPERATION \(\triangle\) & \\
\hline [symbol] & 0 & \(\mathrm{r}_{1}, \mathrm{~d}_{2}\left(\mathrm{x}_{2}, \mathrm{~b}_{2}\right)\)
\end{tabular}

Implicit Format:
\begin{tabular}{c|l|l} 
LABEL & \(\triangle\) OPERATION \(\Delta\) & \\
\hline [symbol] & 0 & \(r_{1}, s_{2}\left(x_{2}\right)\)
\end{tabular}

When the \(O\) instruction is executed, a logical OR operation is performed on a bit in operand 1 and a bit in operand 2. The result of that OR operation replaces the accessed bit in operand 1. This instruction operates from left to right starting with the logical OR operation of bit 0 in both operands up to and including the logical OR operation of bit 31 in both operands.

The O instruction is used to modify bits in the receiving field. The procedure is shown in the following truth table:
\begin{tabular}{|c|c|c|}
\hline Operand 1 & Operand 2 & \begin{tabular}{c} 
Result \\
(Operand 1)
\end{tabular} \\
\hline 0 & 0 & 0 \\
1 & 0 & 1 \\
0 & 1 & 1 \\
1 & 1 & 1 \\
\hline
\end{tabular}

When coding patterns are used as operands in logical OR instructions, the following codes are set:
- 0 in all bit positions in operand 2 that correspond to bit positions in operand 1 that you want to remain the same.
- 1 in all bit positions in operand 2 that correspond to bit positions in operand 1 that you want to set to 1 .

After the O instruction is executed, the condition code is set as follows:
To 0 if result is all 0 's
To 1 if result is a combination of 1 's and 0 's.
Operational Considerations:
- Any of the general registers (0 through 15) can be used as operand 1.
- Operand 2 must be either defined as a full word or aligned on a ful-word boundary.
- The condition code is set accordingly.

\section*{Example:}

1016
\begin{tabular}{|c|c|c|}
\hline & L & 11,NUMX \\
\hline & 0 & 11,PATRNO \\
\hline & - & \\
\hline & - & \\
\hline & DS & \\
\hline & DS & \(\emptyset \mathrm{F}\) \\
\hline NUMX & DC & - \({ }^{\prime}\) ¢øøøFøFø' \\
\hline PATRNO & DC & \(\chi^{\prime}\) 'øøFFのFøF' \\
\hline
\end{tabular}

Register 11 before execution of O instruction:

binary
hex

PATRNO before and after execution of O instruction:

binary
hex

Register 11 after execution of O instruction:

binary
hex

In this example, the content of NUMX is loaded into register 11 and then a logical OR operation is performed on the content of register 11 and the content of PATRNO. The resultant modified binary string replaces register 11.

\section*{OC}
12.18. OR (OC)
\begin{tabular}{|c|c|c|c|c|c|}
\hline \multicolumn{4}{|c|}{General} & \multicolumn{2}{|r|}{Possible Program Exceptions} \\
\hline \multicolumn{2}{|l|}{OPCODE} & \multirow[t]{2}{*}{FORMAT TYPE} & \multirow[t]{2}{*}{\begin{tabular}{l}
OBJECT \\
INST. \\
LGTH. \\
(BYTES)
\end{tabular}} & \multirow[t]{5}{*}{ADDRESSING
DATA (INVALIDSIGN/DIGIT)
DECIMAL DIVIDE
DECIMAL OVERFLOW
EXECUTE
EXPONENT OVERFLOW
EXPONENT UNDERFLOW
FIXED-POINT DIVIDE
FIXED-POINT OVERFLOW
FLOATING-POINT DIVIDE
OPERATION} & \multirow[t]{5}{*}{\begin{tabular}{l}
PROTECTION
SIGNIFICANCE
SPECIFICATION:
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 \\
OP 2 NOT ON DOUBLE-WORD \\
BOUNDARY \\
OP 1 NOT EVEN NUMBERED REGISTER \\
OP 1 NOT ODD NUMBERED REGISTER \\
NONE
\end{tabular}} \\
\hline MNEM. & HEX. & & & & \\
\hline OC & D6 & SS & 6 & & \\
\hline \multicolumn{4}{|c|}{Condition Codes} & & \\
\hline \multicolumn{4}{|l|}{IF RESULT \(=0\), SET TO 0 IF RESULT \(\neq 0\), SET TO 1 IF RESULT \(>0\) O, SET TO 2 IF OVERFLOW, SET TO 3 UNCHANGED} & & \\
\hline
\end{tabular}

The or (OC) instruction performs a logical OR operation (sometimes referred to as an inclusive OR operation) on the contents of operands 1 and 2 located in main storage. The result is placed in operand 1.

Explicit Format:
\begin{tabular}{c|l|l} 
LABEL & DOPERATION \(\triangle\) & \\
\hline [symbol] & OC & \(\mathrm{d}_{1}\left(\mathrm{l}, \mathrm{b}_{1}\right), \mathrm{d}_{2}\left(\mathrm{~b}_{2}\right)\)
\end{tabular}

Implicit Format:
\begin{tabular}{c|l|l} 
LABEL & \(\triangle\) OPERATION \(\Delta\) & \\
\hline [symbol] & OC & \(\mathrm{s}_{1}(1), \mathrm{s}_{2}\)
\end{tabular}

When the OC instruction is executed, a logical OR operation is performed on a bit in operand 1 and a bit in operand 2. The result of the logical OR operation replaces the accessed bit in operand 1. This instruction operates from left to right. The length of operand 1, whether implied or explicit, determines the length of operand 2. Therefore, when the OC instruction is executed, the lengths of operands 1 and 2 are the same.

The OC instruction is used to modify bits in the receiving field．The procedure is shown in the following truth table：
\begin{tabular}{|c|c|c|}
\hline Operand 1 & Operand 2 & \begin{tabular}{c} 
Result \\
（Operand 1）
\end{tabular} \\
\hline 0 & 0 & 0 \\
1 & 0 & 1 \\
0 & 1 & 1 \\
1 & 1 & 1 \\
\hline
\end{tabular}

When coding patterns are used as operands in logical OR instructions，the following codes are set：
－ 0 in all bit positions in operand 2 that correspond to bit positions in operand 1 that you want to remain the same．
－ 1 in all bit positions in operand 2 that correspond to bit positions in operand 1 that you want to set to 1 ．

After the OC instruction is executed，the condition code is set as follows：
To 0 if result is all 0 ＇s．
To 1 if result is a combination of 1 ＇s and 0 ＇s．
Operational Considerations：
－Operands 1 and 2 must be located in main storage．
－The condition code is set accordingly．
－Operands 1 and 2 can have overlapping bytes．

\section*{Example：}
\begin{tabular}{lll} 
LABEL & \(\triangle\) OPERATION \(\triangle 16\) & OPERAND \\
1 & 10 & 16
\end{tabular}
\begin{tabular}{|c|c|c|}
\hline & 0 C & CONSTANT，CONDITI \\
\hline & OC & CONSTANT，CONDIT2 \\
\hline & － & \\
\hline & － & \\
\hline CONSTANT & DC & B＇øøøбぁぁøめ＇ \\
\hline CONDITI & DC & B＇øøбббø11＇ \\
\hline CONDIT2 & DC & B＇0め1010日め＇ \\
\hline
\end{tabular}

CONSTANT before execution of OC instruction:


Before and after execution of OC instruction:
CONDIT1
\begin{tabular}{|c|c|}
\hline 0000 & 0011 \\
\hline 0 & 3 \\
\hline
\end{tabular}
\begin{tabular}{c|c|}
\hline CONDIT2 & \\
\begin{tabular}{|c|c|}
\hline 0010 & 1000 \\
\hline 2 & 8 \\
\hline
\end{tabular} & \begin{tabular}{l} 
binary \\
hex
\end{tabular}
\end{tabular}

CONSTANT after execution of first OC instruction:


CONSTANT after execution of second OC instruction:
\begin{tabular}{|c|c|}
\hline 0010 & 1011 \\
\hline 2 & B \\
\hline
\end{tabular}
binary
hex

In this example, a logical OR operation is performed on the contents of CONSTANT and CONDIT1 and the result is placed in CONSTANT. Then, another logical OR operation is performed on the contents of CONSTANT (now modified) and CONDIT2. That result replaces the contents of CONSTANT. This is an example of the way programmed switches can be used to set several conditions.
12.19. OR (OI)


Condition Codes
IF RESULT \(=0\), SET TO O
- if result \(\neq 0\), SET to 1F RESULT >0, SET TO 2 IF OVERFLOW, SET TO 3 -unchanged
\begin{tabular}{|c|c|}
\hline \multicolumn{2}{|r|}{Possible Program Exceptions} \\
\hline addressing
data (invalid sign/digit)
decimal divide
decimal overflow
execute
EXPONENT OVERFLOW
exponent underflow
FIXED-POINT DIVIDE
FIXED-POINT OVERFLOW
FLOATING-POINT DIVIDE
operation & \begin{tabular}{l}
PROTECTION \\
SIGNIFICANCE \\
SPECIFICATION: \\
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 OP 2 NOT ON DOUBLE-WORD BOUNDARY \\
OP 1 NOT EVEN NUMBERED REGISTER op 1 NOT ODD NUMBERED REGISTER NONE
\end{tabular} \\
\hline
\end{tabular}

The or immediate (OI) instruction performs a logical OR operation on the contents of operand 1 located in main storage and the one byte of immediate data in operand 2. The result replaces one byte in operand 1.

\section*{Explicit Format:}
\begin{tabular}{c|l|l} 
LABEL & DOPERATION \(\Delta\) & \\
\hline [symbol] & OI & \(d_{1}\left(b_{1}\right), i_{2}\)
\end{tabular}

Implicit Format:
\begin{tabular}{c|l|l} 
LABEL & \(\triangle\) OPERATION \(\triangle\) & \\
\hline [symbol] & OI & \(\mathrm{s}_{1}, \mathrm{i}_{2}\)
\end{tabular}

When the Ol instruction is executed, a logical OR instruction is performed on a bit in operand 1 and a bit in operand 2. The result of the logical OR operation replaces the accessed bit in operand 1. This instruction operates from left to right. The length of operand 1 can vary but the length of operand 2 is always one byte. Although operands 1 and 2 may have differing lengths, only one byte in operand 1 is used in the logical OR operation. The result replaces the one byte in operand 1 that was accessed. If you do not specify the exact byte in operand 1 you want used in the logical OR operation, the first byte of operand 1 is used.

The OI instruction is used to modify bits in the receiving field. The procedure is shown in the following truth table.
\begin{tabular}{|c|c|c|}
\hline Operand 1 & Operand 2 & \begin{tabular}{c} 
Result \\
(Operand 1)
\end{tabular} \\
\hline 0 & 0 & 0 \\
1 & 0 & 1 \\
0 & 1 & 1 \\
1 & 1 & 1 \\
\hline
\end{tabular}

When coding patterns are used as operands in logical OR instructions, the following codes are set:
- 0 in all bit positions in operand 2 that correspond to bit positions in operand 1 that you want to remain the same.
- 1 in all bit positions in operand 2 that correspond to bit positions in operand 1 that you want to set to 1.

After the OI instruction is executed, the condition code is set as follows:
To 0 if result is all 0 's.
To 1 if result is a combination of 1 's and 0's.
Operational Considerations:
- Operand 1 must be a main storage location.
- Operand 2 must be a 1 -byte self-defining term.
- The length of operand 1 can vary.
- The condition code is set accordingly.
- You can specify the exact byte in operand 1 you want used in the logical OR operation through relative addressing.

\section*{Example:}
\begin{tabular}{|c|c|c|c|}
\hline LABEL & \multicolumn{2}{|l|}{\(\triangle\) OPERATION \(\triangle\)} & \multirow[t]{2}{*}{OPERAND} \\
\hline 1 & 10 & 16 & \\
\hline & AP & AMTP, VAL & \\
\hline & UNPK & AMT (5) , AMTP & \\
\hline & 01 & AMT \(+4, X^{\prime} \mathrm{F} \square^{\prime}\) & \\
\hline & - & & \\
\hline & - & & \\
\hline AMTP & \({ }_{\text {D }} \mathrm{C}\) & PL3'652' & \\
\hline VAL & DC & P'522' & \\
\hline AMT & DS & ZL5 & \\
\hline
\end{tabular}

AMT before execution of Ol instruction:


Operand 2 immediate before and after execution of Ol instruction:


AMT after execution of OI instruction:
\begin{tabular}{|c|c|c|c|c|c|c|c|c|c|}
\hline 1111 & 0000 & 1111 & 0001 & 1111 & 0001 & 111110111 & 1111 & 10100 \\
\hline F & 0 & \(F\) & 1 & \(F\) & 1 & \(F\) & 7 & \(F\) & 4 \\
\hline
\end{tabular}
binary
hex

In this example, the packed decimal contents of AMTP and VAL are added together and the result is placed in AMTP. Then the UNPK instruction changes the packed format of AMTP to the zoned decimal format and puts the result in AMT. In order to print a decimal number, it must be in zoned decimal format and each number must be preceded by a hexadecimal F. Otherwise, an alpha character will be printed as the rightmost byte. Note that the last byte in AMT has a hexadecimal \(C\) in its zone portion. The Ol instruction allows a logical OR operation to be performed on the contents of byte 5 in AMT and the one byte of data in operand 2. The result replaces byte 5 of AMT. Now the decimal number in AMT can be printed.

\section*{OR}

\subsection*{12.20. OR (OR)}


The or (OR) instruction performs a logical OR operation on the contents of the operand 1 register and operand 2 register. The result is placed in the operand 1 register and also determines the setting of the condition code, bits 34 and 35 of the PSW. (See 8.1.)

Explicit and Implicit Format:


When the OR instruction is executed, a logical OR operation is performed on a bit in the operand 1 and operand 2 registers. The result of the logical OR operation replaces the accessed bit in operand 1. This instruction operates from left to right starting with the execution of the logical OR operation on bit 0 in both registers up to and including bit 31 in both registers.

The OR instruction is used to modify bits in the receiving field. The procedure is shown in the following truth table:
\begin{tabular}{|c|c|c|}
\hline Operand 1 & Operand 2 & \begin{tabular}{c} 
Result \\
(Operand 1)
\end{tabular} \\
\hline 0 & 0 & 0 \\
1 & 0 & 1 \\
0 & 1 & 1 \\
1 & 1 & 1 \\
\hline
\end{tabular}

When coding patterns are used as operands in logical OR instructions, the following codes are set:
- 0 in all bit positions in operand 2 that correspond to bit positions in operand 1 that you want to remain the same.
- 1 in all bit positions in operand 2 that correspond to bit positions in operand 1 that you want to set to 1 .

After the OR instruction is executed, the condition code is set as follows:
To 0 if result is all 0 's.
To 1 if result is a combination of 1's and 0's.

\section*{Operational Considerations:}
- Any of the general registers (0 through 15) can be used as operands 1 and 2.
- The condition code is set accordingly.

\section*{Example:}
\begin{tabular}{lll} 
LABEL & \(\triangle O P E R A T I O N \triangle\) & OPERAND \\
10 & 10 &
\end{tabular}
\begin{tabular}{|c|c|c|}
\hline & L & 4,HEX\#1 \\
\hline & L & 8,HEX\#2 \\
\hline & OR & 4,8 \\
\hline & - & \\
\hline & - & \\
\hline & DS & \(\emptyset F\) \\
\hline HEX\#1 & DC & X'øøめ1ø1cめ' \\
\hline HEX\#2 & DC & \(\chi^{\prime} \emptyset C \emptyset A \emptyset F F 5{ }^{\prime}\) \\
\hline
\end{tabular}

Register 4 before execution of OR instruction:


Register 8 before and after execution of OR instruction:

binary
hex

Register 4 after execution of OR instruction:

binary
hex

In this example, the content of HEX\#1 is loaded into register 4 and the content of HEX\#2 is loaded into register 8 . Then a logical OR operation is performed on the contents of registers 4 and 8 . The result replaces the content of register 4 .

\subsection*{12.21. SHIFT LEFT SINGLE LOGICAL (SLL)}


The shift left single logical (SLL) instruction shifts all of the 32 bits in the operand 1 register to the left the number of bits specified by the low order six bits of the operand 2 address.

Explicit Format:
\begin{tabular}{c|c|l} 
LABEL & DOPERATION \(\triangle\) & \\
\hline [symbol] & SLL & \(r_{1}, d_{2}\left(b_{2}\right)\)
\end{tabular}

Implicit Format
\begin{tabular}{c|l|l} 
LABEL & \(\triangle\) OPERATION \(\triangle\) & \\
\hline [symbol] & SLL & \(r_{1}, s_{2}\)
\end{tabular}

The operand 2 address is not used to address data. The low order six bits are used as the shift count and the remainder of the address is ignored. When the SLL instruction is executed, the high order bits that are shifted out of the register are lost and replaced with subsequent bits within the register also being shifted. Zeros fill the vacated low order bit positions.

Operational Considerations:
- Any of the general registers (0 through 15) can be used as operand 1.
- If you already know the displacement value associated with a label in your program, you can use the low order six bits as the shift count.
- A self-defining term can be specified for operand 2.
- Zeros fill the vacated low order bit positions in the operand 1 register.
- The condition code remains unchanged.
- A length attribute cannot be specified for operand 2.
- The shift count cannot exceed 32 bits because the highest value that can be represented in the low order six bits is \(+32\left(2^{5}\right)\).

\section*{Example:}
```

LABEL \triangleOPERATION\triangle OPERAND
1 10 16

```
\begin{tabular}{lll} 
& L & 4, FLWRD \\
& SLL & 4, STORAGE \\
& ! & \\
& DS & \\
& \\
FLWRD & DC & \(x^{\prime} 89 A B C D E F \prime\) \\
STORAGE & EQU & 8
\end{tabular}

Register 4 before execution of SLL instruction:


STORAGE before and after execution of SLL instruction:


Register 4 after execution of SLL instruction:


In this example, the content of FLWRD is loaded into register 4. Then the SLL instruction uses the low order six bits of the address of STORAGE (not content) as the shift count. In this case, STORAGE has no content but has been equated with or contains the address of the absolute value of 8 . When the SLL instruction is executed, eight high order bits of register 4 are shifted out of the register, and replaced with subsequent bits within the register also being shifted. Zeros fill the vacated eight low order bit positions.

\section*{Example:}

\section*{LABEL \(\triangle O P E R A T I O N \triangle\)}

OPERAND
\begin{tabular}{lll}
10 & 10 & 16
\end{tabular}
\begin{tabular}{ll} 
SR & 4,4 \\
\(L\) & \(4,=F^{\prime} 25 \varnothing \varnothing^{\prime}\) \\
\(L\) & \(5,=F^{\prime} 1 \varnothing^{\prime}\) \\
SLL & \(4, \varnothing(5)\) \\
\(\cdot\) & \\
\(\cdot\) & \\
&
\end{tabular}

Register 4 before execution of SLL instruction:


Register 5 before and after execution of SLL instruction:


Register 4 after execution of SLL instruction:
\begin{tabular}{|c|c|c|c|c|c|c|c|}
\hline 0000 & 0000 & 0010 & 0111 & 0001 & 0000 & 0000 & 0000 \\
\hline 0 & 0 & 2 & 7 & 1 & 0 & 0 & 0 \\
\hline
\end{tabular}

> binary hex

In this example, register 4 is cleared to 0 . The decimal value of 2500 is loaded into register 4, and the decimal value of 10 is loaded into register 5 . The actual content of register 5 is used (not its address) because register 5 is being used as a base register. So, the value loaded into register 5 is treated as an address. This can only be done in the explicit format.

\section*{SRL}
12.22. SHIFT RIGHT SINGLE LOGICAL (SRL)
\begin{tabular}{|c|c|c|c|c|c|c|}
\hline \multicolumn{4}{|c|}{General} & \multicolumn{3}{|r|}{Possible Program Exceptions} \\
\hline \multicolumn{2}{|l|}{OPCODE} & \multirow[t]{2}{*}{FORMAT TYPE} & \multirow[t]{2}{*}{\begin{tabular}{l}
OBJECT \\
INST. \\
LGTH. \\
(BYTES)
\end{tabular}} & \multirow[t]{5}{*}{ADDRESSING
DATA (INVALID SIGN/DIGIT)
DECIMAL DIVIDE
DECIMAL OVERFLOW
EXECUTE
EXPONENT OVERFLOW
EXPONENT UNDERFLOW
FIXED-POINT DIVIDE
FIXED-POINT OVERFLOW
FLOATING-POINT DIVIDE
OPERATION} & \multicolumn{2}{|l|}{\multirow[t]{5}{*}{\begin{tabular}{l}
PROTECTION
SIGNIFICANCE
SPECIFICATION:
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 \\
OP 2 NOT ON DOUBLEWORD \\
BOUNDARY \\
OP 1 NOT EVEN NUMBERED REGISTER \\
OP 1 NOT ODD NUMBERED REGISTER \\
NONE
\end{tabular}}} \\
\hline MNEM. & HEX. & & & & & \\
\hline SRL & 88 & RS & 4 & & & \\
\hline \multicolumn{4}{|c|}{Condition Codes} & & & \\
\hline \multicolumn{4}{|l|}{IF RESULT \(=0\), SET TO 0 IF RESULT < O, SET TO 1 IF RESULT \(>0\) O, SET TO 2 IF OVERFLOW, SET TO 3 UNCHANGED} & & & \\
\hline
\end{tabular}

The shift right single logical (SRL) instruction shifts all of the 32 bits in the operand 1 register to the right the number of bits specified by the low order six bits of the operand 2 address.

Explicit Format:


Implicit Format:
\begin{tabular}{c|l|l} 
LABEL & \(\triangle\) OPERATION \(\triangle\) & \\
\hline [symbol] & SRL & \(\mathrm{r}_{1}, \mathrm{~s}_{2}\)
\end{tabular}

The operand 2 address is not used to address data. The low order six bits are used as the shift count and the remainder of the address is ignored. When the SRL instruction is executed, the low order bits that are shifted out of the register are lost and replaced with subsequent bits within the register also being shifted. Zeros fill the vacated high order bit positions.

Operational Considerations:
- Any of the general registers ( 0 through 15 ) can be used as operand 1.
- Using a label as operand 2 can cause unpredictable results.
- A self-defining term can be used as operand 2.
- Zeros fill the vacated high order bit positions in the operand 1 register.
- The condition code remains unchanged.
- A length attribute cannot be specified for operand 2.
- The shift count cannot exceed 32 bits because the highest value that can be represented in the low order six bits is \(+32\left(2^{5}\right)\).

\section*{Example:}
\begin{tabular}{lll} 
LABEL & \(\triangle O P E R A T I O N \triangle\) & OPERAND \\
1 & 10 & 16
\end{tabular}
\begin{tabular}{|c|c|c|}
\hline & L & 4, WORD \\
\hline & SRL & 4, LABEL \\
\hline & - & \\
\hline & - & \\
\hline & - & \\
\hline WORD & DC & X'3A6øøøøø \\
\hline LABEL & DC & PL2'ø1 \\
\hline
\end{tabular}

Register 4 before execution of SRL instruction:

binary
hex

Address of LABEL:


Register 4 after execution of SRL instruction:
\begin{tabular}{|c|c|c|c|c|c|c|c|}
\hline 0000 & 0000 & 0000 & 0000 & 0000 & 0011 & 1010 & 0110 \\
\hline 0 & 0 & 0 & 0 & 0 & 3 & \(A\) & 6 \\
\hline
\end{tabular}
binary
hex

In this example, the content of WORD is loaded into register 4. Then the SRL instruction uses the low order six bits of the address location counter of LABEL as the shift count. You should already know the displacement value of LABEL. That value should be the number of bits you want to shift to the right. When the SRL instruction is executed, 20 low order bits of register 4 are shifted out of the register, and replaced with subsequent bits within the register also being shifted. Zeros fill the vacated 20 high order bits. This is what LABEL looks like when assembled:
\begin{tabular}{|llll|}
\hline LOC. OBJECT CODE & LINE SOURCE STATEMENT \\
\(000014000 C\) & 14 LABEL & DC & PL2'0' \\
\hline
\end{tabular}

\section*{STC}

\subsection*{12.23. STORE CHARACTER (STC)}
\begin{tabular}{|c|c|c|c|}
\hline \multicolumn{4}{|c|}{General} \\
\hline \multicolumn{2}{|l|}{OPCODE} & \multirow{2}{*}{\[
\begin{aligned}
& \text { FORMAT } \\
& \text { TYPE }
\end{aligned}
\]} & \multirow[t]{2}{*}{\begin{tabular}{l}
object INST LGTH. \\
(BYTES)
\end{tabular}} \\
\hline MNEM. & HEX. & & \\
\hline STC & 42 & RX & 4 \\
\hline
\end{tabular}

Condition Codes
\(\square\) IF RESULT \(=0\), SET TO O if result \(<0\), setto 1 if Result >o, SET to 2 if overflow, set to 3 unchanged
\begin{tabular}{|l|l|}
\hline \multicolumn{2}{|c|}{ Possible Program Exceptions } \\
\hline\(\square\) ADDRESSING & \(\square\) PROTECTION \\
\(\square\) DATA (INVALIDSIGN/DIGIT) & \(\square\) SIGNIFICANCE \\
\(\square\) DECIMAL DIVIDE & \(\square\) SPECIFICATION: \\
\(\square\) DECIMAL OVERFLOW & \(\square\) \\
\(\square\) EXECUTE & \(\square\) \\
\(\square\) NOT A FLOATING-POINT REGISTER \\
\(\square\) & OP 1 NOT ON HALF-WORD BOUNDARY \\
\(\square\) EXPONENT UNDERFLOW & \(\square\) \\
\(\square\) FIXED-POINT DIVIDE & \(\square\) OP 2 NOT ON HALF-WORD BOUNDARY \\
\(\square\) FIXED-POINT OVERFLOW & \(\square\) OP 2 NOT ON DOUBLE-WORD \\
\(\square\) FLOATING-POINT DIVIDE & \(\square\) BOUNDARY \\
\(\square\) OPERATION & \(\square\) OP 1 NOT EVEN NUMBERED REGISTER \\
& \(\square\) NONE 1 NOT ODD NUMBERED REGISTER \\
\hline
\end{tabular}

The store character (STC) instruction places the low order eight bits (bit positions 24 through 31) of the operand 1 register into one byte of operand 2 that is located in main storage.

Explicit Format:
\begin{tabular}{c|l|l} 
LABEL & \(\triangle\) OPERATION \(\triangle\) & \\
\hline [symbol] & STC & \(\mathrm{r}_{1}, \mathrm{~d}_{\mathbf{2}}\left(\mathrm{x}_{2}, \mathrm{~b}_{2}\right)\)
\end{tabular}

Implicit Format:
\begin{tabular}{c|l|l} 
LABEL & \(\triangle\) OPERATION \(\triangle\) & \\
\hline [symbol] & STC & \(r_{1}, s_{2}\left(x_{2}\right)\)
\end{tabular}

The data in operand 2 can be defined in any format. The length of operand 2 can vary but the length of operand 1 is always four bytes. Although operands 1 and 2 can have the same or differing length, only one byte in operand 2 receives the rightmost byte from the operand 1 register. If you do not specify the exact byte in operand 2 to receive the operand 1 data, the first byte of operand 2 is used.

\section*{Operational Considerations:}
- Any of the general iegisters ( 0 through 15) can be used as operand 1.
- Operand 2 must be a main storage location.
- The length of operand 2 can vary.
- You can specify the exact byte in operand 2 to receive the rightmost byte of the operand 1 register through relative addressing.
- This instruction is one of the few in which operand 1 is the sending operand.

Example:
\begin{tabular}{|c|c|c|c|}
\hline \multirow[t]{2}{*}{\[
\underset{1}{\text { LABEL }}
\]} & \multicolumn{2}{|l|}{\(\triangle\) OPERATION \(\triangle\)} & \multirow[t]{2}{*}{OPERAND} \\
\hline & 10 & 16 & \\
\hline & L & 11,AMTIN & \\
\hline & A & 11,=F'5' & \\
\hline & STC & 11,STOR & \\
\hline & - & & \\
\hline & - & & \\
\hline AMTIN & DC & \(F^{\prime} 22361\) & \\
\hline STOR & DC & CL4'61 & \\
\hline
\end{tabular}

STOR before execution of STC instruction:
\begin{tabular}{|c|c|c|c|c|c|c|c|}
\hline 1111 & 0000 & 0100 & 0000 & 0100 & 0000 & 0100 & 0000 \\
\hline\(F\) & 0 & 4 & 0 & 4 & 0 & 4 & 0 \\
\hline
\end{tabular}
binary
hex

Register 11 before and after execution of STC instruction:

binary
hex

STOR after execution of STC instruction:

binary
hex

In this example, the content of AMTIN is loaded into register 11. Then a decimal value of 5 is added to the value already in register 11. This is a method of rounding numbers located in registers that will eventually be printed. The STC instruction then places the content of the rightmost byte in register 11 into the first byte of STOR. Since the exact byte of STOR that is to receive the data from register 11 is not specified, the first byte is used.

\section*{TM}

\subsection*{12.24. TEST UNDER MASK (TM)}


The test under mask (TM) instruction uses the 1-byte mask in operand 2 to test the bit pattern of one byte in operand 1 that is located in main storage. The result of the test determines the setting of the condition code, bits 34 and 35 of the PSW. (See 8.1.)

\section*{Explicit Format:}
\begin{tabular}{c|l|ll} 
LABEL & पOPERATION \(\triangle\) & & OPERAND \\
\hline [symbol] & TM & \(\mathrm{d}_{1}\left(\mathrm{~b}_{1}\right), \mathrm{i}_{2}\)
\end{tabular}

Implicit Format:
\begin{tabular}{c|l|l} 
LABEL & \multicolumn{1}{|c|}{\(\triangle\) OPERATION \(\triangle\)} & \\
\hline [symbol] & TM & \(\mathrm{s}_{1}, \mathrm{i}_{2}\)
\end{tabular}

Operand 2 is one byte of immediate data that is used as the mask. Within that byte is an 8 -bit binary testing pattern. The bits of the mask correspond one for one to bits in one byte of operand 1. The length of operand 1 can vary but the length of operand 2 is always one byte. Although the lengths of operands 1 and 2 can differ, only one byte of operand 1 is used. If you do not specify the exact byte of operand 1 you want tested, the first byte is used.

A mask bit of one in operand 2 tests its corresponding bit position in operand 1 for the presence of one bit or a 0 bit.

A mask bit of 0 in operand 2 causes its corresponding bit position in operand 1 not to be tested. If the mask pattern is all 0 's, no testing takes place; whereas, if the mask pattern is all 1 's, every corresponding bit position in operand 1 is tested.

The condition code is set as follows:
To 0 if the mask pattern is all 0 's; or all the corresponding tested bit positions in operand 1 are 0 's.

To 1 if all the corresponding tested bit positions in operand 1 are a combination of 0 's and 1 's.

To 3 if all the corresponding tested bit positions in operand 1 are 1 's
Some of the more common uses of the test under mask instruction are in checking the setting of program switches and checking for valid characters. These switches are usually set by one of the logical OR instructions. After the switches are set, the TM instruction uses the mask to test the bit pattern in operand 1 and set the condition code. Then the resulting condition code can be used to alter the processing sequence of a program by using one of these branch instructions:
\begin{tabular}{|c|c|c|c|c|}
\hline \multicolumn{2}{|c|}{Mnemonic Code} & \multirow{2}{*}{Meaning} & \multirow{2}{*}{Remarks} & \multirow[t]{2}{*}{Branches on Condition Code} \\
\hline RR-Type Instruction & RX-Type Instruction & & & \\
\hline BOR & BO & Branch if 1's. & The branch is taken if all the bits tested are on. & 3 \\
\hline BMR & BM & Branch if mixed. & The branch is taken if some of the bits tested are on, some off. & 1 \\
\hline BZR & BZ & Branch if 0 's. & The branch is taken if all of the bits are off, or the mask is 0 . & 0 \\
\hline BNOR & BNO & Branch if not all 1 's. & The branch is taken if at least one of the bits tested is not on. & 0,1 \\
\hline BNZR & BNZ & Branch if not all O's. & The branch is taken if at least one of the bits tested is not off. & 1,3 \\
\hline BNMR & BNM & Branch if not mixed. & The branch is taken if all the bits tested are off or if all are on. & 0,3 \\
\hline
\end{tabular}

\section*{Operational Considerations:}
- Operand 1 must be a main storage location.
- Operand 2 is the mask and is a 1 -byte self-defining term.
- The condition code is set accordingly but condition code 2 is not used.
- The length of operand 1 can vary but a length attribute cannot be specified.
- You can specify the exact byte in operand 1 you want the operand 2 mask to test through relative addressing.
- The contents of operand 1 and operand 2 remain unchanged after the execution of the TM instruction.

Example:


PAYHRS before and after execution of first and second TM instruction:


Operand 2 mask before and after execution of first and second TM instruction:


In this example, the address of PAYHRS is loaded into register 5. The TM instruction then uses the mask in operand 2 to test the first byte in operand 1. The four high order bits of the mask test the four high order bits of operand 1. (The low order four bits of the mask cause no testing of the low order four bits of operand 1 to take place.) Since the result of the test is all 1 's, the condition code is set to 3 and no branch takes place.

The second TM instruction uses the mask in operand 2 to test the second byte in operand 1. The four high order bits of the mask test the four high order bits of the second byte in operand 1. (The low order four bits of the mask cause no testing of the low order four bits of operand 1 to take place.) Since the result of the test is a combination of 0's and 1 's, the condition code is set to 1 and the branch to the instruction labeled ERROR2 takes place. There, an error message is moved to the output area for printing.

\subsection*{12.25. TRANSLATE (TR)}


The translate (TR) instruction gets a byte from a table of characters in operand 2 and places it in its corresponding byte of operand 1.

\section*{Explicit Format:}
\begin{tabular}{c|l|l} 
LABEL & \(\triangle\) OPERATION \(\triangle\) & \\
\hline [symbol] & TR & \(d_{1}\left(1, b_{1}\right), d_{2}\left(b_{2}\right)\)
\end{tabular}

Implicit Format:
\begin{tabular}{c|l|ll} 
LABEL & DOPERATION \(\Delta\) & & OPERAND \\
\hline [symbol] & TR & \(s_{1}(1), s_{2}\)
\end{tabular}

The translate instruction can translate the bit pattern of each byte in a field (operand 1) to any other bit pattern. This instruction works in conjunction with a table (operand 2) that has been previously defined within the program, and contains the bit patterns that correspond to each byte in operand 1. This instruction operates from left to right, starting with the replacement of the leftmost byte in operand 1, and ending with the replacement of the rightmost byte in operand 1 . To find the appropriate code in the table (operand 2), each byte in the operand 1 field is used as an unsigned binary value that is added to the address of the first byte in the table. (The sum of the addition is similar to the addition of base register and displacement values.)

The result of the addition is another address which should be somewhere within the table． The one byte of data that is located at that address replaces the 8 －bit binary value of operand 1 that was used in the addition to arrive at that location．After the first byte is replaced，the second byte is operated upon and replaced，and so on until the end of the operand 1 field is reached．

Since there are 256 different combinations of an 8－bit byte（EBCDIC），the maximum size of the translate table is 256 bytes．However，you can define a table smaller than that because input data is normally restricted to a smaller range．

The translate instruction can be used to convert data from one code to another code（i．e．， octal to hexadecimal）or it can be used to rearrange data to be stored in a specific sequence．

Operational Considerations：
－Operand 1 must be a main storage location and can be defined in any format．
－Operand 2 must be a table that is previously defined within the program．
－Operand 2 cannot exceed 256 bytes in length．
－One byte in operand 2 replaces one byte in operand 1.
－Each byte in operand 1 is treated as an unsigned binary value which is added to the address of the first byte in operand 2.

Example：
\begin{tabular}{|c|c|c|c|}
\hline LABEL & \(\triangle\) OPE & & OPERAND \\
\hline 1 & 10 & 16 & \\
\hline & TR & FIELD，TABLE & \\
\hline & － & & \\
\hline & － & & \\
\hline FIELD & DC & X＇66A4C5F71 & \\
\hline TABLE & DS & ®CL256 & \\
\hline & DC & 106x＇øめ＇ & \\
\hline & DC &  & \\
\hline & DC & 50x＇01 & \\
\hline & DC & Х＇ØВøСФDØEØF1ø111213＇ & \\
\hline & DC & 1ヵx＇øø＇ & \\
\hline & DC & X＇1415161718191A1BIC＇ & \\
\hline & DC & 50x＇めぁ1 & \\
\hline & DC & X＇1DIE1F2ø212223242526＇ & \\
\hline & DC & 4X＇あぁ＇ & \\
\hline
\end{tabular}

FIELD before execution of TR instruction:


FIELD after execution of TR instruction:

binary
hex

In this example, FIELD (operand 1) contains four addresses to be added to the address of the first byte of TABLE (operand 2), one at a time, to access a specific byte within the table. The table with the label TABLE is defined as part of this program.

The first byte in operand 1, a hexadecimal 66, has a decimal equivalence of 102. When a decimal value of 102 is added to the address of the first byte in TABLE, the 103rd byte in the table (a hexadecimal 03), is accessed. That byte replaces the hexadecimal 66 and the second byte in operand 1 is processed.

The second byte in operand 1 (a hexadecimal A4) has a decimal equivalence of 164. When a decimal value of 164 is added to the address of the first byte in TABLE, the 165th byte in the table (a hexadecimal OF) is accessed. That byte replaces the hexadecimal A4 and the third byte in operand 1 is processed.

The third byte in operand 1 (a hexadecimal C5) has a decimal equivalence of 197. When a decimal value of 197 is added to the address of the first byte in TABLE, the 198th byte in the table (a hexadecimal 00 ) is accessed. That byte replaces the hexadecimal C5 and the fourth byte in operand 1 is processed.

The fourth byte in operand 1 (a hexadecimal F7) has a decimal equivalence of 247. When a decimal value of 247 is added to the address of the first byte in TABLE, the 248th byte in the table (a hexadecimal 26) is accessed. That byte replaces the hexadecimal F7 and the TR instruction terminates.

\section*{TRT}

\subsection*{12.26. TRANSLATE AND TEST (TRT)}

\begin{tabular}{|c|c|}
\hline \multicolumn{2}{|r|}{Possible Program Exceptions} \\
\hline \begin{tabular}{l}
ADDRESSING \\
DATA (INVALID SIGN/DIGIT) \\
DECIMAL DIVIDE \\
DECIMAL OVERFLOW \\
EXECUTE \\
EXPONENT OVERFLOW \\
EXPONENT UNDERFLOW \\
FIXED-POINT DIVIDE \\
FIXED-POINT OVERFLOW \\
FLOATING-POINT DIVIDE \\
OPERATION
\end{tabular} & \begin{tabular}{l}
PROTECTION
SIGNIFICANCE
SPECIFICATION:
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 OP 2 NOT ON DOUBLE-WORD BOUNDARY \\
OP 1 NOT EVEN NUMBERED REGISTER OP 1 NOT ODD NUMBERED REGISTER NONE
\end{tabular} \\
\hline
\end{tabular}

The translate and test (TRT) instruction gets a byte from a table of characters in operand 2 and examines it for the presence of a hexadecimal 00 . If found, it continues processing with the next byte in operand 1. If not found, execution of the TRT instruction is terminated and the address of that byte in operand 1 and the nonzero byte in the table are saved. The result of the byte examination in the table determines the setting of the conditon code, bits 34 and 35 of the PSW. (See 8.1.)

\section*{Explicit Format:}
\begin{tabular}{c|c|c} 
LABEL & \(\triangle\) OPERATION \(\triangle\) & \\
\hline [symbol] & TRT & \(d_{1}\left(1, b_{1}\right), d_{2}\left(b_{2}\right)\)
\end{tabular}

Implicit Format:


This instruction works in conjunction with a table (operand within the program and contains bit patterns that correspond to each byte in operand 1. This instruction operates from left to right starting with the first byte in operand 1 and ending with the last byte in operand 1 or, when a nonzero byte is found in the table. To find the appropriate code in the table (operand 2), each byte in the operand 1 field is used as an unsigned binary value which is added to the address of the first byte in the table. This method of accessing a byte from a table is performed in the same manner as the translate (TR) instruction.

The result of the addition of an unsigned binary value to the address of the first byte is another address which should be somewhere within the table. The one byte of data that is located at that address is examined for the presence of a hexadecimal 00 . If found, processing continues with the next byte in operand 1. If a hexadecimal 00 is not found, execution of the TRT instruction is terminated.

The address of that byte in operand 1 is inserted in the low order 24 bits of register 1, with the high order eight bits remaining unchanged. The nonzero byte from the table is inserted in the low order eight bits of register 2, with the high order 24 bits remaining unchanged.

The condition code is set as follows:
To 0 if all the bytes examined in the table are 0
To 1 if a nonzero character is found in the table before the last byte in operand 1 is processed

To 2 if a nonzero character is found in the table that corresponds to the last byte in operand 1

The translate and test instruction is used to find certain characters in an input stream. You can set up operand 2 (table) with all 0 bytes for those characters to be skipped over and all nonzero bytes for those characters to be detected and used.

Operational Considerations:
- Operand 1 must be a main storage location and can be defined in any format.
- Operand 2 must be a table that is previously defined within the program.
- Operand 2 cannot exceed 256 bytes in length.
- Each selected byte in the table (operand 2) is examined for the presence of a hexadecimal 00.
- Each byte in operand 1 is treated as an unsigned binary vlaue which is added to the address of the first byte in operand 2.
- The condition code is set accordingly.

Example：
\begin{tabular}{|c|c|c|c|}
\hline LABEL & \multicolumn{2}{|l|}{\(\triangle\) OPERATION \(\triangle\)} & \multirow[t]{2}{*}{OPERAND} \\
\hline 1 & 10 & 16 & \\
\hline & TRT & AREAIN，TRTTABLE & \\
\hline & － & & \\
\hline & － & & \\
\hline AREAIN & D \({ }^{\text {c }}\) & X＇324848＇ & \\
\hline TRTTABLE & DS & ØCL256 & \\
\hline & DC & 64x＇00＇ & \\
\hline & DC & 人4あり & \\
\hline & DC & 191×＇061 & \\
\hline
\end{tabular}

Register 1 after execution of TRT instruction：


Register 2 after execution of TRT instruction：


In this example，the only nonzero byte in the table is the 65th byte which is the address of the first byte in the table +64 ．The hexadecimal 40 at that location causes the TRT instruction to terminate．Then the address of the blank，also a hexadecimal 40，is put into register 1．The nonzero character in the table，a blank，is put in the rightmost byte of register 2．The condition code is set to 1 since a nonzero character is found in the table before the last byte in operand 1 has been processed．

\title{
13. Privileged and Status Switching Instructions
}

\subsection*{13.1. GENERAL}

A privileged instruction is an instruction used by the operating system. A privileged instruction cannot be used in a program operating under the SPERRY UNIVAC Operating System/3 (OS \(/ 3\) ). If a program operating under \(\mathrm{OS} / 3\) uses a privileged instruction, a privileged operation program exception causes the program to terminate without executing.

The privileged instructions are included in this book because they can be assembled under OS/3 even though they can't be executed.

The checkoff table used with each instruction is explained in Appendix D.
Some of the status-switching instructions are also privileged, but three are not. These instructions are set program mask (SPM), supervisor call (SVC), and test and set (TS).

Since the status switching instructions manipulate portions of the program status word (PSW), it might be helpful to read the PSW field description in 8.1.

\subsection*{13.2. STATUS-SWITCHING PRIVILEGED INSTRUCTIONS}

The status-switching instructions can change the program status word (PSW), the contents of the protect key storage, and the current relocation register.

\section*{HPR}

\subsection*{13.2.1. Halt and Proceed (HPR)}
\begin{tabular}{|c|c|c|c|}
\hline \multicolumn{4}{|c|}{General} \\
\hline \multicolumn{2}{|l|}{opcode} & \multirow{2}{*}{FORMAT TYPE} & \multirow[t]{2}{*}{} \\
\hline MNEM. & HEX. & & \\
\hline HPR & 99 & SI & 4 \\
\hline
\end{tabular}
\begin{tabular}{|c|c|}
\hline \multicolumn{2}{|r|}{Possible Program Exceptions} \\
\hline ADDRESSING
DATA (INVALID SIGN/DIGIT)
DECIMAL DIVIDE
DECIMAL OVERFLOW
EXECUTE
EXPONENT OVERFLOW
EXPONENT UNDERFLOW
FIXED-POINT DIVIDE
FIXED-POINT OVERFLOW
FLOATING-POINT DIVIDE
OPERATION & \begin{tabular}{l}
PROTECTION
significance
SPECIFICATION:
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
OP 2 NOT ON DOUBLE-WORD \\
BOUNDARY
op 1 NOT EVEN NUMBERED REGISTER \\
OP 1 NOT ODD NUMBERED REGISTER
NONE
\end{tabular} \\
\hline
\end{tabular}

\section*{Explicit Format:}
\begin{tabular}{l|l|l}
\multicolumn{1}{c|}{ LABEL } & \(\triangle\) OPERATION \(\triangle\) & \\
\hline [symbol] & HPR & \\
HALTHERE & HPR & \(\mathrm{d}_{1}\left(\mathrm{~b}_{1}\right), \mathrm{i}_{2}\) \\
& & \(0(5), 81\)
\end{tabular}

Implicit Format:
\begin{tabular}{c|l|l} 
LABEL & \(\triangle\) OPERATION \(\triangle\) & \\
\hline [symboi] & HPR & \(\mathrm{s}_{1}, \mathrm{i}_{2}\) \\
& HPR & TAGERAND X'FF'
\end{tabular}

\subsection*{13.2.2. Insert Storage Kev (ISK)}
\begin{tabular}{|c|c|c|c|}
\hline \multicolumn{4}{|c|}{ General } \\
\hline OPCODE & FORMAT & \begin{tabular}{l} 
OBJECT \\
INST. \\
TYPE
\end{tabular} \\
\begin{tabular}{c|c|c|} 
LGTH. \\
(BYTES)
\end{tabular} \\
\hline MNEM. & HEX. & & 2 \\
\hline ISK & \(\mathbf{0 9}\) & RR & 2 \\
\hline
\end{tabular}
\begin{tabular}{|c|c|}
\hline \multicolumn{2}{|r|}{Possible Program Exceptions} \\
\hline ADDRESSING
DATA (INVALID SIGN/DIGIT)
DECIMAL DIVIDE
DECIMAL OVERFLOW
EXECUTE
EXPONENT OVERFLOW
EXPONENT UNDERFLOW
FIXED-POINT DIVIDE
FIXED-POINT OVERFLOW
FLOATING-POINT DIVIDE
OPERATION & PROTECTION
SIGNIFICANCE
SPECIFICATION:
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 OP 2 NOT ON DOUBLE-WORD BOUNDARY OP 1 NOT EVEN NUMBERED REGISTER OP 1 NOT ODD NUMBERED REGISTER NONE \\
\hline
\end{tabular}

Explicit and Implicit Format:
\begin{tabular}{l|l|ll}
\multicolumn{1}{c|}{ LABEL } & \(\triangle\) OPERATION \(\triangle\) & & OPERAND \\
\hline [SYmbol] & ISK & \(r_{1}, r_{2}\) & \\
INKEY & ISK & 3,4
\end{tabular}

\section*{LCS}

\subsection*{13.2.3. Load Control Storage (LCS)}
\begin{tabular}{|c|c|c|c|}
\hline \multicolumn{4}{|c|}{ General } \\
\hline OPCODE & FORMAT & \begin{tabular}{l} 
OBJECT \\
INST. \\
TYPE \\
LGTH. \\
(BYTES)
\end{tabular} \\
\hline MNEM. & HEX. & & 4 \\
\hline LCS & B1 & RS & 4 \\
\hline
\end{tabular}
\begin{tabular}{|c|c|}
\hline \multicolumn{2}{|r|}{Possible Program Exceptions} \\
\hline \begin{tabular}{l}
ADDRESSING \\
DATA (INVALID SIGN/DIGIT)
DECIMAL DIVIDE
DECIMAL OVERFLOW
EXECUTE
EXPONENT OVERFLOW
EXPONENT UNDERFLOW
FIXED-POINT DIVIDE
FIXEDPOINT OVERFLOW
FLOATING-POINT DIVIDE
OPERATION
\end{tabular} & \begin{tabular}{l}
PROTECTION
SIGNIFICANCE \\
SPECIFICATION: \\
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 OP 2 NOT ON DOUBLEWORD BOUNDARY OP 1 NOT EVEN NUMBERED REGISTER OP 1 NOT ODD NUMBERED REGISTER NONE
\end{tabular} \\
\hline
\end{tabular}

4
EXPONENT OVERFLOWFIXEO-POINT DIVIDEFLOATING-POINT DIVIDE
OPERATION
    SET TO O
    SETTO 1
    SET TO 2
    SET TO 3
    UNCHANGED

\section*{Explicit Format:}
\begin{tabular}{l|l|l}
\multicolumn{1}{c|}{ LABEL } & \(\triangle\) OPERATION \(\triangle\) & \\
\hline [symbol] & LCS & \multicolumn{1}{c}{ OPERAND } \\
LOD & LCS & \(r_{1}, r_{3}, d_{2}\left(b_{2}\right)\) \\
& & \(5,3,32(8)\)
\end{tabular}

\section*{Implicit Format:}
\begin{tabular}{l|l|l}
\multicolumn{1}{c|}{ LABEL } & \multicolumn{1}{c}{ OPERATION \(\triangle\)} & \multicolumn{1}{c}{ OPERAND } \\
\hline [symbol] & LCS & \(r_{1}, r_{3}, s_{2}\) \\
LOD & LCS & 5,3, TAG4 (2)
\end{tabular}

\section*{LPSW}

\subsection*{13.2.4. Load Program Status Word (LPSW)}


\section*{Explicit Format:}
\begin{tabular}{l|l|l}
\multicolumn{1}{c|}{ LABEL } & \(\triangle\) OPERATION \(\triangle\) & \\
\hline [symbol] & LPSW & \(\mathrm{d}_{1}\left(\mathrm{~b}_{1}\right), \mathrm{i}_{2}\) \\
LODSTAT & LPSW & \(32(16), 00\)
\end{tabular}

Implicit Format:
\begin{tabular}{l|l|ll}
\multicolumn{1}{c|}{ LABEL } & \multicolumn{1}{c|}{\(\triangle\) OPERATION \(\triangle\)} & & OPERAND \\
\hline [symbol] & LPSW & \(\mathrm{s}_{1}, \mathrm{i}_{2}\) & \\
LODSTAT & LPSW & STORAGE,00 &
\end{tabular}

\section*{SSK}

\subsection*{13.2.5. Set Storage Key (SSK)}


Explicit and Implicit Format:
\begin{tabular}{l|l|ll} 
LABEL & DOPERATION \(\triangle\) & & OPERAND \\
\hline [symbol] & SSK & \(r_{1}, r_{2}\) & \\
SETKEY & SSK & 2,3 &
\end{tabular}

\subsection*{13.2.6. Set System Mask (SSM)}
\begin{tabular}{|c|c|c|c|}
\hline \multicolumn{4}{|c|}{General} \\
\hline \multicolumn{2}{|l|}{opcode} & \multirow{2}{*}{FORMAT
TYPE} & \multirow[t]{2}{*}{OBJECT INST. LGTH. (BYTES} \\
\hline MNEM. & HEX. & & \\
\hline SSM & 80 & SI & 4 \\
\hline \multicolumn{4}{|c|}{Condition Codes} \\
\hline \multicolumn{4}{|l|}{F RESULT \(=0\), SET TO 0
fresult <0, SET to 1
if RESULT \(>0\), SET TO 2
if overflow, SET TO 3 unchanged} \\
\hline
\end{tabular}
\begin{tabular}{|c|c|}
\hline \multicolumn{2}{|r|}{Possible Program Exceptions} \\
\hline \begin{tabular}{l}
ADDRESSING \\
DATA (INVALIDSIGN/DIGIT)
DECIMAL DIVIDE
DECIMAL OVERFLOW
EXECUTE
EXPONENT OVERFLOW
EXPONENT UNDERFLOW
FIXED-POINT DIVIDE
FIXED-POINT OVERFLOW
FLOATING-POINT DIVIDE operation
\end{tabular} & \begin{tabular}{l}
PROTECTION
SIGNIFICANCE \\
SPECIFICATION: \\
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 \\
OP 2 NOT ON DOUBLE-WORD \\
BOUNDARY \\
OP 1 NOT EVEN NUMBERED REGISTER \\
OP 1 NOT ODD NUMBERED REGISTER \\
NONE
\end{tabular} \\
\hline
\end{tabular}

\section*{Explicit Format:}
\begin{tabular}{l|l|ll}
\multicolumn{1}{c|}{ LABEL } & \(\triangle\) OPERATION \(\triangle\) & & OPERAND \\
\hline [symbol] & SSM & \(\mathrm{d}_{1}\left(\mathrm{~b}_{1}\right)\) & \\
SETSM & SSM & \(6(32)\) &
\end{tabular}

Implicit Format:
\begin{tabular}{l|l|l}
\multicolumn{1}{c|}{ LABEL } & \(\triangle\) OPERATION \(\Delta\) & \\
\hline [symbol] & SSM & \(\mathbf{s}_{1}\) \\
SETSM & SSM & SYSMASK
\end{tabular}

\subsection*{13.3. INPUT/OUTPUT PRIVILEGED INSTRUCTION}

There is one privileged instruction that initiates input and output: the start \(1 / 0\) (SIO) instruction. When the SIO instruction is executed, the processor stops executing instructions and waits while input and output routines are using the processing time.

\section*{SIO}

\subsection*{13.3.1. Start I/O (SIO)}
\begin{tabular}{|c|c|c|c|}
\hline \multicolumn{4}{|c|}{ General } \\
\hline OPCODE & FORMAT & \begin{tabular}{l} 
OBJECT \\
INST. \\
TGTH. \\
LGYTES)
\end{tabular} \\
\hline MNEM. & HEX. & & \begin{tabular}{c} 
(BYTES)
\end{tabular} \\
\hline SIO & 9C & SI & \(\mathbf{4}\) \\
\hline
\end{tabular}
\begin{tabular}{|c|c|}
\hline \multicolumn{2}{|r|}{Possible Program Exceptions} \\
\hline ADDRESSING
DATA (INVALID SIGN/DIGIT)
DECIMAL DIVIDE
decimal overflow
EXECUTE
EXPONENT OVERFLOW
EXPONENT UNDERFLOW
FIXED-POINT DIVIDE
FIXED-POINT OVERFLOW
FLOATING-POINT DIVIDE
operation & \begin{tabular}{l}
PROTECTION
SIGNIFICANCE
SPECIFICATION:
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 OP 2 NOT ON DOUBLE-WORD BOUNDARY \\
OP 1 NOT EVEN NUMBERED REGISTER OP 1 NOT ODD NUMBERED REGISTER NONE
\end{tabular} \\
\hline
\end{tabular}

Explicit Format:
\begin{tabular}{l|l|ll}
\multicolumn{1}{c|}{ LABEL } & \multicolumn{1}{|c}{\(\triangle\) OPERATION \(\triangle\)} & & OPERAND \\
\hline [symbol] & SIO & \(d_{1}\left(b_{1}\right)\) \\
INOUT & SIO & \(32(5)\) &
\end{tabular}

Implicit Format:
\begin{tabular}{l|l|l}
\multicolumn{1}{c|}{ LABEL } & \(\triangle\) OPERATION \(\triangle\) & \\
\hline [Symbol] & SIO & \(\mathrm{s}_{1}\) \\
INOUT & SIO & STORERAND \\
& &
\end{tabular}

\subsection*{13.4. DIAGNOSTIC PRIVILEGED INSTRUCTIONS}

The diagnostic instructions are diagnose (DIAG), SOFTSCOPE forward scan (SSFS), and SOFTSCOPE reverse scan (SSRS). The SOFTSCOPE instructions select and monitor any bus wire carrying information to or from a byte of main storage. The diagnose instruction resets the processor to 0 after control storage is loaded.

\section*{DIAG}

\subsection*{13.4.1. Diagnose (DIAG)}


\section*{Explicit Format:}
\begin{tabular}{l|l|l}
\multicolumn{1}{c|}{ LABEL } & \(\triangle\) OPERATION \(\triangle\) & \\
\hline [symbol] & DIAG & \(\mathrm{d}_{1}\left(\mathrm{~b}_{1}\right), \mathrm{i}_{2}\) \\
SETZERO & DIAG & \(32(6), 00\)
\end{tabular}

Implicit Format:
\begin{tabular}{l|l|l}
\multicolumn{1}{c|}{ LABEL } & \(\triangle\) OPERATION \(\Delta\) & \\
\hline [symbol] & DIAG & \(\mathrm{s}_{1}, \mathrm{i}_{2}\) \\
SETZERO & DIAG & STORAGE,00 \\
& &
\end{tabular}

\section*{SSFS}

\subsection*{13.4.2. SOFTSCOPE Forward Scan (SSFS)}

\section*{1}
\(\left.\)\begin{tabular}{|c|c|c|c|}
\hline \multicolumn{4}{|c|}{ General } \\
\hline OPCODE & FORMAT \\
TYPE
\end{tabular} \begin{tabular}{l} 
OBJECT \\
INST. \\
LGTH. \\
(BYTES)
\end{tabular} \right\rvert\,
\begin{tabular}{|c|c|}
\hline \multicolumn{2}{|r|}{Possible Program Exceptions} \\
\hline - addressing & - PROTECTION \\
\hline \(\square\) DATA (INVALIDSIGN/DIGIT) & \(\square\) SIGNIFICANCE \\
\hline \(\square\) DECIMAL DIVIDE & \(\square\) SPECIFICATION: \\
\hline \(\square\) DECIMAL OVERFLOW & \(\square\) NOT A FLOATING-POINT REGISTER \\
\hline \(\square\) EXECUTE & \(\square\) OP 1 NOT ON HALF-WORD BOUNDARY \\
\hline \(\square\) EXPONENT OVERFLOW & \(\square\) OP 2 NOT ON HALF-WORD BOUNDARY \\
\hline \(\square\) EXPONENT UNDERFLOW & \(\square\) OP 2 NOT ON FULL-WORD BOUNDARY \\
\hline \(\square\) FIXED-POINT DIVIDE & \(\square\) OP 2 NOT ON DOUBLEWORD \\
\hline \(\square\) FIXED-POINT OVERFLOW & BOUNDARY \\
\hline FLOATING-POINT DIVIDE & of 1 NOT EVEN NUMBERED REGISTER OP 1 NOT ODD NUMBERED REGISTER \\
\hline Ration & NONE \\
\hline
\end{tabular}

\section*{Explicit and Implicit Format:}

The bit pattern is the format of the instruction.

\section*{SSR}

\subsection*{13.4.3. SOFTSCOPE Reverse Scan (SSRS)}


Explicit and Implicit Format:
The bit pattern is the format of the instruction.

\subsection*{13.5. INTERNAL TIMER PRIVILEGED INSTRUCTION}

The OS /3 hardware contains an internal timer register that is controlled by the service timer register (STR) instruction.

\section*{STR}

\subsection*{13.5.1. Service Timer Register (STR)}


Explicit and Implicit Format:
\begin{tabular}{l|l|l} 
LABEL & \(\triangle\) OPERATION \(\triangle\) & \\
\hline [Symbol] & STR & \(\mathrm{r}_{1}, \mathrm{r}_{\mathbf{2}}\) \\
TIMREG & STR & \(\mathbf{5 , 6}\)
\end{tabular}

\section*{SLM}

\subsection*{13.6. GENERAL REGISTER PRIVILEGED INSTRUCTIONS}

These instructions operate on the problem general register set.

\subsection*{13.6.1. Supervisor Load Multiple (SLM) Instruction}
\begin{tabular}{|c|c|c|c|c|c|c|}
\hline \multicolumn{4}{|c|}{General} & \multicolumn{3}{|r|}{Possible Program Exceptions} \\
\hline \multicolumn{2}{|l|}{OPCODE} & \multirow[t]{2}{*}{FORMAT TYPE} & \multirow[t]{2}{*}{\begin{tabular}{l}
OBJECT \\
INST. \\
LGTH. \\
(BYTES)
\end{tabular}} & \multirow[t]{5}{*}{\begin{tabular}{l}
ADDRESSING \\
DATA (INVALID SIGN/DIGIT) \\
DECIMAL DIVIDE \\
DECIMAL OVERFLOW \\
EXECUTE \\
EXPONENT OVERFLOW \\
EXPONENT UNDERFLOW \\
FIXED-POINT DIVIDE \\
FIXED-POINT OVERFLOW \\
FLOATING-POINT DIVIDE \\
OPERATION
\end{tabular}} & \multicolumn{2}{|l|}{\multirow[t]{5}{*}{\begin{tabular}{l}
PROTECTION
SIGNIFICANCE
SPECIFICATION:
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 OP 2 NOT ON DOUBLE-WORD BOUNDARY \\
OP 1 NOT EVEN NUMBERED REGISTER \\
OP 1 NOT ODD NUMBERED REGISTER \\
NONE
\end{tabular}}} \\
\hline MNEM. & HEX. & & & & & \\
\hline SLM & 88 & RS & 4 & & & \\
\hline \multicolumn{4}{|c|}{Condition Codes} & & & \\
\hline \multicolumn{4}{|l|}{IF RESULT \(=0\). SET TO O
IF RESULT < O, SET TO 1
if RESULT \(>0\) O, SET TO 2
IF OVERFLOW, SET TO 3 unchanged} & & & \\
\hline
\end{tabular}

Explicit Format:
\begin{tabular}{l|l|l} 
LABEL & \(\triangle\) OPERATION \(\triangle\) & \\
\hline & & OPERAND \\
[symbol] & SLM & \(\mathbf{r}_{1}, r_{3}, d_{2}\left(b_{2}\right)\) \\
LOAD36 & SLM & \(3,6,20(9)\)
\end{tabular}

Implicit Format:
\begin{tabular}{c|l|l} 
LABEL & \(\triangle\) OPERATION \(\Delta\) & \\
\hline [Symbol] & SLM & \\
LOPERAND \\
& SLM & \(\mathrm{r}_{1}, \mathrm{r}_{3}, \mathrm{~s}_{2}\) \\
& & 3,6, DATAFIVE
\end{tabular}

\subsection*{13.6.2. Supervisor Store Multiple (SSTM) Instruction}
\begin{tabular}{|c|c|c|c|c|c|c|}
\hline \multicolumn{4}{|c|}{General} & \multicolumn{3}{|r|}{Possible Program Exceptions} \\
\hline \multicolumn{2}{|l|}{OPCODE} & \multirow[t]{2}{*}{\[
\begin{aligned}
& \text { FORMAT } \\
& \text { TYPE }
\end{aligned}
\]} & \multirow[t]{2}{*}{\begin{tabular}{l}
OBJECT \\
INST. \\
LGTH. \\
(BYTES)
\end{tabular}} & \multirow[t]{5}{*}{ADDRESSING
DATA (INVALID SIGN/DIGIT)
DECIMAL DIVIDE
DECIMAL OVERFLOW
EXECUTE
EXPONENT OVERFLOW
EXPONENT UNDERFLOW
FIXED-POINT DIVIDE
FIXED-POINT OVERFLOW
FLOATING-POINT DIVIDE
OPERATION} & \multicolumn{2}{|l|}{\multirow[t]{5}{*}{PROTECTION
SIGNIFICANCE
SPECIFICATION:
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 OP 2 NOT ON DOUBLE WORD BOUNDARY OP 1 NOT EVEN NUMBERED REGISTER OP 1 NOT ODD NUMBERED REGISTER NONE}} \\
\hline MNEM. & HEX. & & & & & \\
\hline SSTM & B0 & RS & 4 & & & \\
\hline \multicolumn{4}{|c|}{Condition Codes} & & & \\
\hline \multicolumn{4}{|l|}{IF RESULT \(=0\), SET TO O if result <o. Set to 1
if RESULT \(>0\) O. SET TO 2
if overflow, set to 3 unchanged} & & & \\
\hline
\end{tabular}

\section*{Explicit Format:}
\begin{tabular}{l|l|l} 
LABEL & \(\triangle\) OPERATION \(\triangle\) & \\
\hline & & OPERAND \\
[symbol] & SSTM & \(\mathbf{r}_{1}, \mathbf{r}_{3}, \mathbf{d}_{2}\left(\mathbf{b}_{2}\right)\) \\
STORE47 & SSTM & \(4,7,0(2)\)
\end{tabular}

Implicit Format:
\begin{tabular}{l|l|l} 
LABEL & \(\triangle\) OPERATION \(\triangle\) & \\
\hline [Symbol] & SSTM & \\
STORE47 & SSTM & \(\mathbf{r}_{1}, r_{3}, s_{2}\) \\
& & 4,7, AREATWO
\end{tabular}

\section*{SPM}

\subsection*{13.7. SET PROGRAM MASK (SPM) STATUS-SWITCHING INSTRUCTION}


The set program mask (SPM) instruction replaces bits 34 through 39 of the current PSW with bits 2 through 7 of the operand 1 register.

\section*{Explicit and Implicit Format:}
\begin{tabular}{l|l|l}
\multicolumn{1}{c|}{ LABEL } & \(\triangle\) OPERATION \(\triangle\) & \\
\hline [symbol] & SPM & \(r_{1}\) \\
SETM & SPM & 3
\end{tabular}

Operational Considerations:
- Bits 0,1 , and 8 through 31 of the operand 1 register are ignored by the \(O S / 3\) hardware.
- The condition code is set equal to bit positions 2 and 3 of operand 1 .

Example:
\begin{tabular}{|c|c|c|c|}
\hline LABEL 1 & \[
\begin{aligned}
& \triangle \text { OPERA } \\
& 10
\end{aligned}
\] & 16 & OPERAND \\
\hline & - & & \\
\hline & - & & \\
\hline LODREG & L & 3,MASK & \\
\hline SETM & SPM & 3 & \\
\hline & - & & \\
\hline & & & \\
\hline MASK & DC & \(F^{\prime} 11\) & \\
\hline
\end{tabular}

In this example, I loaded register 3 with the contents of a main storage area called MASK. MASK contains a full word of binary 1's. When the SPM instruction is executed, bits 34 through 39 of the PSW are replaced with bits 2 through 7 of register 3.

\subsection*{13.8. SUPERVISOR CALL (SVC) STATUS-SWITCHING INSTRUCTION}


The supervisor call (SVC) instruction causes an interrupt and replaces bits 24 through 31 of the current PSW with the 1-byte contents of operand 1.

Explicit and Implicit Format:
\begin{tabular}{l|l|ll}
\multicolumn{1}{c|}{ LABEL } & \(\triangle\) OPERATION \(\Delta\) & & OPERAND \\
\hline [symbol] & SVC & \(i_{1}\) & \\
SUPCALL & SVC & 38 &
\end{tabular}

Operational Considerations:
- The operand you specify is an immediate byte of data, which is a 1-byte absolute term.
- Once the SVC instruction is executed, the PSW with its new contents is stored, and a new PSW is controlling your program.
- The condition code is equal to bits 34 and 35 of the PSW after the supervisor call is granted.

\section*{Example:}
\begin{tabular}{llll} 
LABEL & \multicolumn{2}{c}{\begin{tabular}{l}
\(\triangle O P E R A T I O N \Delta\) \\
10
\end{tabular}} & OPERAND \\
\hline CALL & SVC & \(X^{\prime} O F^{\prime}\) &
\end{tabular}

A supervisor call interrupt is generated, and the value \(\mathrm{X}^{\prime} 00001111^{\prime}\) is stored in the old PSW.

\subsection*{13.9. TEST AND SET (TS) STATUS-SWITCHING INSTRUCTION}
\begin{tabular}{|c|c|c|c|c|c|c|c|}
\hline \multicolumn{4}{|c|}{General} & \multicolumn{4}{|c|}{Possible Program Exceptions} \\
\hline \multicolumn{2}{|l|}{OPCODE} & \multirow[t]{2}{*}{FORMAT TYPE} & \multirow[t]{2}{*}{\begin{tabular}{l}
OBJECT \\
INST. \\
LGTH. \\
(BYTES)
\end{tabular}} & \multirow[t]{8}{*}{ADDRESSING
DATA (INVALIDSIGN/DIGIT)
decimal divide
DECIMAL OVERFLOW
EXECUTE
EXPONENT OVERFLOW
EXPONENT UNDERFLOW
FIXED-POINT DIVIDE
FIXED-POINT OVERFLOW
FLOATING-POINT DIVIDE
operation} & \multicolumn{3}{|l|}{\multirow[t]{8}{*}{\begin{tabular}{l}
PROTECTION
SIGNIFICANCE
SPECIFICATION:
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 OP 2 NOT ON DOUBLE-WORD BOUNDARY \\
OP 1 NOT EVEN NUMBERED REGISTER \\
OP 1 NOT ODD NUMBERED REGISTER \\
NONE
\end{tabular}}} \\
\hline MNEM. & HEX. & & & & & & \\
\hline TS & 93 & S & 4 & & & & \\
\hline & & & & & & & \\
\hline \multicolumn{4}{|c|}{Condition Codes} & & & & \\
\hline \multicolumn{4}{|l|}{\multirow[t]{3}{*}{\begin{tabular}{l}
SET TO O \\
SET TO 1
SET TO 2
SET TO 3 \\
SEE OPER. CONSIDERATIONS
\end{tabular}}} & & & & \\
\hline & & & & & & & \\
\hline & & & & & & & \\
\hline
\end{tabular}

The test and set (TS) instruction tests the zero bit of the operand 1 main storage area for a 1 or a 0 and sets the condition code according to the result.

\section*{NOTE:}

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

Explicit Format:
\begin{tabular}{l|l|ll}
\multicolumn{1}{c|}{ LABEL } & \(\triangle\) OPERATION \(\Delta\) & & OPERAND \\
\hline [symbol] & TS & \(\mathrm{d}_{2}\left(\mathrm{~b}_{2}\right)\) \\
TEST & TS & \(32(16)\) &
\end{tabular}

Implicit Format:
\begin{tabular}{l|l|l}
\multicolumn{1}{c|}{ LABEL } & \(\triangle\) OPERATION \(\triangle\) & \\
\hline [symbol] & TS & \(\mathbf{s}_{2}\) \\
TEST & TS & STORERAND \\
& &
\end{tabular}

Operational Considerations:
- Only the leftmost bit of the operand is tested to determine the condition code setting.
- All eight bits of the operand byte are set to 1 after the condition code is set.
- The condition code is set as follows:
- to 0 if the tested bit is 0 ; or
- to 1 if the tested bit is 1 .
- This instruction can be used by two programs referencing the same main storage byte. A condition code setting of 0 indicates that the area is available for use by the testing program. A condition code setting of 1 indicates that the area is not available.

Example:


When the TS instruction is executed, the leftmost bit of BYTE is tested. Since the bit is 1 , the condition code is set to 1 .

\section*{14. Featured Instructions}

This section contains the instructions that are featured. You cannot use a featured instruction unless your processor has the control feature. If you attempt to use these instructions without the control feature, you cause an operation program exception.

Within this section, the instructions are grouped alphabetically by instruction category. Within each category, they are grouped alphabetically by instruction name.

The explanation of the checkoff table used for each instruction in this section is included in Appendix D.

\subsection*{14.1. FEATURED BRANCHING INSTRUCTIONS}

The featured branching instructions are described in 14.1.1 and 14.1.2. (See Section 8 for descriptions of the remaining branching instructions.)

\section*{BXH}

\subsection*{14.1.1. Branch on Index High (BXH)}


The branch on index high ( BXH ) instruction algebraically compares the sum of the operand 1 register and operand 3 register to either the operand 3 register or one greater than the operand 3 register (comparand register). If the sum is greater than the content of the comparand register, a branch to the instruction located at the operand 2 address takes place. If a greater than condition does not exist, your program continues processing with the instruction following the BXH instruction. The sum is always placed in the operand 1 register after the comparison.

\section*{Explicit Format:}
\begin{tabular}{c|l|l} 
LABEL & \(\triangle\) OPERATION \(\triangle\) & \\
\hline [symbol] & BXH & \(r_{1}, r_{3}, d_{2}\left(b_{2}\right)\)
\end{tabular}

Implicit Format:
\begin{tabular}{c|l|l} 
LABEL & \(\triangle\) OPERATION \(\triangle\) & \\
[symbol] & BXH & \(r_{1}, r_{3}, s_{2}\) \\
& &
\end{tabular}

This instruction algebraically adds the content of the operand 1 register to the content of the operand 3 register. The sum is algebraically compared to the content of an oddnumbered register (which can be the same as the operand 3 register) or a register that is one larger than the operand 3 register. If the sum is greater than the content of the oddnumbered register it is being compared to, a branch to the instruction located at the operand 2 address takes place. If the sum is less than or equal to the content of the oddnumbered register it is being compared to, the program continues processing with the instruction following the BXH instruction. Following the comparison, the sum is placed in operand 1. Usually, the BXH instruction is executed several times (depending on program logic) until the content of the operand 1 register is greater than the odd-numbered register it is being compared to. Then the branch to the instruction located at the operand 2 address takes place.

Operational Considerations:
- Any of the general registers (0 through 15) can be used as operands 1 and 3.
- Any odd-numbered register either equal to operand 3 or one greater than operand 3 can be used as the comparand register.
- Operand 2 can be any location in main storage.
- The rules of algebra apply to both the addition and the comparison operations.
- The condition code remains unchanged.

Example:
\begin{tabular}{|c|c|c|c|}
\hline \multirow[t]{2}{*}{LABEL} & \multicolumn{2}{|l|}{\(\triangle O P E R A T I O N \triangle\)} & \multirow[t]{2}{*}{OPERAND} \\
\hline & 10 & 16 & \\
\hline & LA & 3,4 & \\
\hline & LA & 4,10 & \\
\hline & LA & 5,11 & \\
\hline & BXH & 3,4,L00P & \\
\hline & AP & CARDIN, = \({ }^{\prime}\) 5øø' & \\
\hline & - & & \\
\hline & - & & \\
\hline LOOP & \(\stackrel{C}{P}\) & CARDIN, MAXIMUM & \\
\hline & - & & \\
\hline & \(\cdot\) & & \\
\hline CARDIN & \({ }^{\circ} \mathrm{C}\) & PL3'ゆ' & \\
\hline maximum & DC & PL3'10øø日' & \\
\hline
\end{tabular}

Registers 3 and 4 before execution of BXH instruction:
\begin{tabular}{|c|c|c|c|c|c|c|c|}
\hline 0000 & 0000 & 0000 & 0000 & 0000 & 0000 & 0000 & 0100 \\
\hline 0 & 0 & 0 & 0 & 0 & 0 & 0 & 4 \\
\hline
\end{tabular}
\begin{tabular}{|c:c|c:c|c:c|c|c|}
\hline 0000 & 0000 & 0000 & 0000 & 0000 & 0000 & 0000 & 1010 \\
\hline 0 & 0 & 0 & 0 & 0 & 0 & 0 & \(A\) \\
\hline
\end{tabular}
binary hex

Register 5 (comparand register) before and after execution of BXH instruction:
\begin{tabular}{|c|c|c|c|c|c|c|}
\hline 0000 & 0000 & 0000 & 0000 & 0000 & 0000 & 0000 \\
\hline 0 & 0 & 0 & 0 & 0 & 0 & 0 \\
\hline
\end{tabular}
binary
hex

Registers 3 and 4 after execution of BXH instruction:
\begin{tabular}{|c|c|c|c|c|c|c:c|}
\hline 0000 & 0000 & 0000 & 0000 & 0000 & 0000 & 0000 & 1110 \\
\hline 0 & 0 & 0 & 0 & 0 & 0 & 0 & \(E\) \\
\hline
\end{tabular}
\begin{tabular}{|c|c|c|c|c|c|c|c|}
\hline 0000 & 0000 & 0000 & 0000 & 0000 & 0000 & 0000 & 1010 \\
\hline 0 & 0 & 0 & 0 & 0 & 0 & 0 & A \\
\hline
\end{tabular}\(\quad\)\begin{tabular}{l} 
binary \\
hex
\end{tabular}

In this example, the decimal value 4 is loaded into register 3, the decimal value of 10 is loaded into register 4, and the decimal value of 11 is loaded into the comparand register 5. When the BXH instruction is executed, the contents of registers 3 and 4 are algebraically added together, the sum being decimal value 14 (hexadecimal E ). The sum is algebraically compared to the content of register 5 and then placed in register 3. Since the sum is greater than the content of register 5, a branch to the instruction labeled LOOP takes place. There, the content of CARDIN is compared to the content of MAXIMUM.

\section*{BXLE}
14.1.2. Branch on Index Low or Equal (BXLE)
\begin{tabular}{|c|c|c|c|}
\hline \multicolumn{4}{|c|}{ General } \\
\hline OPCODE & FORMAT & \begin{tabular}{l} 
OBJECT \\
INST. \\
TYPE \\
LGTH. \\
(BYTES)
\end{tabular} \\
\hline MNEM. & HEX. & & \(\mathbf{4}\) \\
\hline BXH & 87 & RS & 4 \\
\hline
\end{tabular}
Condition Codes
\begin{tabular}{l}
\(\square\) IF RESULT \(=0\), SET TO 0 \\
IF RESULT \(<0\), SET TO 1 \\
IF RESULT \(>0\), SET TO 2 \\
IFOVERFLOW, SET TO 3 \\
UNCHANGED \\
\hline
\end{tabular}
\begin{tabular}{|c|c|}
\hline \multicolumn{2}{|r|}{Possible Program Exceptions} \\
\hline addressing
data (invalidsign/digit)
decimal divide
decimal overflow
execute
EXPONENT OVERFLOW
exponent underflow
fixed-point divide
fIXED-POINT OVERFLOW
floating-point divide
operation & \begin{tabular}{l}
PROTECTION
significance
SPECIFICATION:
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 OP 2 NOT ON DOUBLE-WORD BOUNDARY \\
op 1 not even numbered register op 1 NOT ODD NUMBERED REGISTER
NONE
\end{tabular} \\
\hline
\end{tabular}

The branch on index low or equal (BXLE) instruction algebraically compares the sum of the operand 1 register and operand 3 register to either the operand 3 register or one greater than the operand 3 register (comparand register). If the sum is less than or equal to the content of the comparand register, a branch to the instruction located at the operand 2 address takes place. If a less than or equal to condition does not exist, the program continues processing with the instruction that follows the BXLE instruction. The sum is always placed in the operand 1 register after the comparison.

Explicit Format:


Implicit Format:


This instruction algebraically adds the content of the operand 1 register to the content of the operand 3 register. The sum is algebraically compared to the content of an oddnumbered register, which can be the same as the operand 3 register, or a register that is one larger than the operand 3 register. If the sum is less than or equal to the content of the odd-numbered register it is being compared to, a branch to the instruction located at the operand 2 address takes place. If the sum is greater than the content of the oddnumbered register it is being compared to, the program continues processing with the
instruction following the BXLE instruction. Following the comparison, the sum is placed in operand 1. Usually, the BXLE instruction is executed several times (depending on program logic) until the content of the operand 1 register is less than or equal to the odd-numbered register to which it is being compared. Then the branch to the instruction located at the operand 2 address takes place.

Operational Considerations:
- Any of the general registers ( 0 through 15) can be used as operands 1 and 3 .
- Any odd-numbered register either equal to operand 3 or one greater than operand 3 can be used as the comparand register.
- Operand 2 can be any location in main storage.
- The rules of algebra apply to both the addition and the comparison operations.
- The condition code remains unchanged.

\section*{Example:}
\begin{tabular}{lll} 
LABEL & \(\triangle\) OPERATION \\
1 & 10 & 16
\end{tabular}\(\quad\) OPERAND
\begin{tabular}{|c|c|c|}
\hline & L & 4,VALUEI \\
\hline & L & 5,VALUE2 \\
\hline & BXLE & 4,5, BRANCHTO \\
\hline NEXTSEQ & AP & A, B \\
\hline BRANCHTO & CP & A, B \\
\hline & - & \\
\hline VALUEI & DC & F'-3' \\
\hline VALUE2 & DC & F'19' \\
\hline A & DC & PL4'2ø6' \\
\hline B & DC & PL2'16' \\
\hline
\end{tabular}

In this example, the values -3 and +10 are loaded into registers 4 and 5, respectively. The BXLE instruction compares the sum of the content of registers 4 and \(5(+7)\) to the content of the comparand register, register 5 . Since +7 is less than 10 , the branch is taken. The next instruction executed (CP) is located at BRANCHTO.

\subsection*{14.2. FEATURED FIXED-POINT INSTRUCTIONS}

The featured fixed-point instructions are described in 14.2.1 through 14.2.10. (See Section 10 for descriptions of the remaining fixed-point instructions.)
14.2.1. Divide (DR)
\begin{tabular}{|c|c|c|c|c|c|}
\hline \multicolumn{4}{|c|}{General} & \multicolumn{2}{|r|}{Possible Program Exceptions} \\
\hline \multicolumn{2}{|l|}{OPCODE} & \multirow[t]{2}{*}{\[
\begin{aligned}
& \text { FORMAT } \\
& \text { TYPE }
\end{aligned}
\]} & \multirow[t]{2}{*}{\begin{tabular}{l}
OBJECT \\
INST. \\
LGTH. \\
(BYTES)
\end{tabular}} & \multirow[t]{5}{*}{ADDRESSING
DATA (INVALIDSIGN/DIGIT)
DECIMAL DIVIDE
DECIMAL OVERFLOW
EXECUTE
EXPONENT OVERFLOW
EXPONENT UNDERFLOW
FIXED-POINT DIVIDE
FIXED-POINT OVERFLOW
FLOATING-POINT DIVIDE
OPERATION} & \multirow[t]{2}{*}{PROTECTION
SIGNIFICANCE
SPECIFICATION:} \\
\hline MNEM. & HEX. & & & & \\
\hline DR & 10 & RR & 2 & & NOT A FLOATING-POINT REGISTER OP 1 NOT ON HALF-WORD BOUNDARY \\
\hline \multicolumn{4}{|c|}{Condition Codes} & & OP 2 NOT ON HALF-WORD BOUNDARY OP 2 NOT ON FULL-WORD BOUNDARY \\
\hline \multicolumn{4}{|l|}{IF RESULT \(=0\), SET TO 0
IF RESULT \(<0\), SET TO 1
IF RESULT \(>0\), SET TO 2
IF OVERFLOW, SET TO 3 UNCHANGED} & & \begin{tabular}{l}
OP 2 NOT ON DOUBLE-WORD \\
BOUNDARY \\
OP 1 NOT EVEN NUMBERED REGISTER \\
OP 1 NOT ODD NUMBERED REGISTER \\
NONE
\end{tabular} \\
\hline
\end{tabular}

The DIVIDE (DR) instruction algebraically divides the contents of the double word in the operand 1 register pair (dividend) by the full word in the operand 2 register. The result (quotient and remainder) is placed in operand 1.

Explicit and Implicit Format:
\begin{tabular}{c|l|ll} 
LABEL & \(\triangle\) OPERATION \(\triangle\) & & OPERAND \\
\hline [symbol] & DR & \(r_{1}, r_{2}\)
\end{tabular}

\section*{Operational Considerations:}
- Operand 1 consists of a pair of contiguous registers (64 bits) containing a fixed-point binary value. The registers are even-odd numbered, the lower numbered register being even. You must specify the even-numbered register as operand 1. The oddnumbered registers must contain the dividend before you can use this instruction. You may specify any of the general registers ( 0 through 15).
- Operand 2 is a 32 -bit register ( 0 through 15 ) containing a fixed-point binary value (dividend). Operand 2 is not changed by the execution of this instruction.
- After the instruction is executed, the quotient with sign is put into the odd-numbered register, and the remainder with the same sign occupies the even-numbered register. If the quotient and remainder do not fill their respective 32-bit fields, leftmost bit positions are filled by bits having the same value as the sign.
- If you attempt to divide by zero, or if the quotient does not fit into the 32-bit oddnumbered register in operand 1, a fixed-point divide program exception occurs.
- The DR instruction is a featured instruction. An operation program exception is caused if you use this instruction and your processor does not have the control feature.

\section*{Example:}
\begin{tabular}{lll} 
LABEL & \(\triangle O P E R A T I O N \Delta\) & OPERAND \\
1 & 10 & 16
\end{tabular}
\begin{tabular}{lll} 
& LM & 6,8, DIVEND \\
& DR & 6,8 \\
& \(\cdot\) & \\
& \(\cdot\) & \\
DIVEND & DC & \(D^{\prime}+64^{\prime}\) \\
DIVISOR & DC & \(F^{\prime}+32^{\prime}\)
\end{tabular}

In this example, registers 6,7 , and 8 are loaded with the main storage contents of DIVEND and DIVISOR, respectively. Then, divide the contents of registers 6 and 7 by the contents of register 8 and placed the result (quotient with sign) in register 7 .

Note that the use of the LM instruction eliminates the writing of three separate load instructions but still loads three registers. Also note that the quotient and its sign are loaded into register 7 and and the remainder with the same sign value as the quotient that occupies register 6.

Registers 6 and 7 before execution of DR instruction:
\begin{tabular}{|c|c|c|c|c|c|c|c|c|c|c|c|c|c|c|c|}
\hline 0000 & 0000 & 0000, & 0000 & 0000 & 0000 & 0000 & 0000 & 0000 & 0000 & 0000, & 0000 & 0000 & 0000 & 0100,0000 \\
\hline 0 & 0 & 0 & 0 & 0 & 0 & 0 & 0 & 0 & 0 & 0 & 0 & 0 & 0 & 4 & 0 \\
\hline
\end{tabular}

Register 8 before and after execution of DR instruction:



Registers 6 and 7 after execution of DR instruction:
\begin{tabular}{|c|c|c|c|c|c|c|c|c|c|c|c|c|c|c:c|}
\hline 0000 & 0000 & 0000 & 0000 & 0000 & 0000 & 0000 & 0000 & 0000 & 0000 & 0000 & 0000 & 0000 & 0000 & 0000 & 0010 \\
\hline 0 & 0 & 0 & 0 & 0 & 0 & 0 & 0 & 0 & 0 & 0 & 0 & 0 & 0 & 0 & 2 \\
\hline
\end{tabular}

\subsection*{14.2.2. Load Complement (LCR)}
\begin{tabular}{|c|c|c|c|c|c|}
\hline \multicolumn{4}{|c|}{General} & \multicolumn{2}{|r|}{Possible Program Exceptions} \\
\hline \multicolumn{2}{|l|}{OPCODE} & \multirow[t]{2}{*}{FORMAT
TYPE} & \multirow[t]{2}{*}{OBJECT INST. LGTH (bytes)} & \multirow[t]{7}{*}{\begin{tabular}{l}
ADDRESSING
DATA (INVALID SIGN/DIGIT)
DECIMAL DIVIDE
DECIMAL OVERFLOW
EXECUTE
EXPONENT OVERFLOW
EXPONENT UNDERFLOW
FIXED-POINT DIVIDE \\
FIXED-POINT OVERFLOW
FLOATING-POINT DIVIDE
operation
\end{tabular}} & \multirow[t]{2}{*}{PROTECTION
significance
SPECIFICATION} \\
\hline MNEM. & HEX. & & & & \\
\hline LCR & 13 & RR & 2 & & \(\square\) OP 1 NOT ON HALF-WORD BOUNDARY \\
\hline \multicolumn{4}{|c|}{Condition Codes} & & \begin{tabular}{l}
OP 2 NOT ON HALF-WORD BOUNDARY \\
OP 2 NOT ON FULL-WORD BOUNDARY
\end{tabular} \\
\hline \multicolumn{4}{|l|}{\multirow[t]{3}{*}{```
IF RESULT = O, SET TO O
IF RESULT<0, SET TO 1
IF RESULT >0, SET TO 2
IF OVERFLOW, SET TO 3
unchanged
```}} & & \begin{tabular}{l}
OP 2 NOT ON DOUBLE-WORD \\
BOUNDARY
\end{tabular} \\
\hline & & & & & OP 1 NOT EVEN NUMBERED REGISTER \\
\hline & & & & & OP 1 NOT ODD NUMBERED REGISTER \\
\hline
\end{tabular}

The load complement (LCR) instruction places the twos complement form of the contents of operand 2 register into the operand 1 register.

Explicit and Implicit Format:
\begin{tabular}{l|l|l} 
LABEL & \(\triangle\) OPERATION \(\triangle\) & \\
\hline [symbol] & LCR & \(r_{1}, r_{2}\)
\end{tabular}

\section*{Operational Considerations:}
- Any of the general registers (0 through 15) can be used as operands 1 and 2.
- If operand 2 is a positive value, the twos complement of that value is placed into operand 1 when the instruction is executed. If the value in operand 2 is negative, the positive value is placed in operand 1 when the instruction is executed. The maximum value you can specify in operand 2 is \(+2,147,483,647\left(2^{31}-1\right)\) or \(-2,147,483,647\) \(\left(-2^{31}-1\right)\).
- A zero value in operand 2 is not changed when complemented.
- Operand 2 is not changed by the execution of the instruction.
- The LCR instruction is a featured instruction. An operation program exception is caused if you use this instruction and your processor does not have the control feature.

\section*{Example:}
\begin{tabular}{lll} 
LABEL & \(\triangle\) OPERATION \\
1 & 10 & 16
\end{tabular}\(\quad\) OPERAND
\begin{tabular}{|c|c|c|}
\hline & L & 5, FULLWORD \\
\hline & LCR & 6,5 \\
\hline & LTR & 6,6 \\
\hline & - & \\
\hline & - & \\
\hline FULLWORD & DC & \(F^{\prime \prime \prime \prime}\) \\
\hline
\end{tabular}

Register 5 before and after execution of LCR instruction:


Register 6 after execution of LCR instruction:


In this example, the contents of FULLWORD is loaded into register 5 and the LCR instruction loads the complement of the content of register 5 into register 6 . Since the result is less than zero, the condition code is set to 1 and the load and test (LTR) instruction (see 10.14) loads the content of register 6 into itself and tests the condition code. Because the registers of operands 1 and 2 in the LTR instruction are the same, the operation is performed as a test without data movement.

\subsection*{14.2.3. Load Negative (LNR)}
\begin{tabular}{|c|c|c|c|c|c|c|}
\hline \multicolumn{4}{|c|}{General} & \multicolumn{3}{|r|}{Possible Program Exceptions} \\
\hline \multicolumn{2}{|l|}{OPCODE} & \multirow[t]{2}{*}{FORMAT TYPE} & \multirow[t]{2}{*}{\begin{tabular}{l}
OBJECT \\
INST. \\
LGTH. \\
(BYTES)
\end{tabular}} & \multirow[t]{5}{*}{ADDRESSING
DATA (INVALIDSIGN/DIGIT)
DECIMAL DIVIDE
DECIMAL OVERFLOW
EXECUTE
EXPONENT OVERFLOW
EXPONENT UNDERFLOW
FIXED-POINT DIVIDE
FIXED-POINT OVERFLOW
FLOATING-POINT DIVIDE
OPERATION} & \multicolumn{2}{|l|}{\multirow[t]{5}{*}{PROTECTION
SIGNIFICANCE
SPECIFICATION:
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 OP 2 NOT ON DOUBLE-WORD BOUNDARY OP 1 NOT EVEN NUMBERED REGISTER OP 1 NOT ODD NUMBERED REGISTER NONE}} \\
\hline MNEM. & HEX. & & & & & \\
\hline LNR & 11 & RR & 2 & & & \\
\hline \multicolumn{4}{|c|}{Condition Codes} & & & \\
\hline \multicolumn{4}{|l|}{IF RESULT = 0, SET TO O IF RESULT<0, SET TO 1 IF RESULT \(>0\), SET TO 2 IF OVERFLOW, SET TO 3 UNCHANGED} & & & \\
\hline
\end{tabular}

The load negative (LNR) instruction places the twos complement of the content of the operand 2 register into the operand 1 register. If operand 2 contains a negative value or a value of zero, the instruction places that value unchanged into operand 1.

Explicit and Implicit Format:
\begin{tabular}{c|c|c} 
LABEL & \(\triangle\) OPERATION \(\triangle\) & \\
\hline [symbol] & LNR & \(r_{1}, r_{2}\)
\end{tabular}

Operational Considerations:
- Any of the general registers ( 0 through 15 ) can be used as operands 1 and 2.
- The LNR instruction is a featured instruction. An operation program exception is caused if you use this instruction and your processor does not have the control feature.

Example:
\begin{tabular}{|c|c|c|c|}
\hline LABEL & \multicolumn{2}{|l|}{\(\triangle O P E R A T I O N \triangle\)} & OPERAND \\
\hline 1 & 10 & 16 & \\
\hline & LM & 5,7,NUMBERS I & \\
\hline & LNR & 5,5 & \\
\hline & LNR & 6,6 & \\
\hline & LNR & 7,7 & \\
\hline &  & & \\
\hline NUMBERSI & \(\dot{\text { D }}\) & \(F^{\prime \prime}{ }^{\prime}\) & \\
\hline NUMBERS2 & DC & \(F^{\prime} 5^{\prime}\) & \\
\hline NUMBERS3 & DC & \(F^{\prime} 6^{\prime}\) & \\
\hline
\end{tabular}

In this example registers 5,6 , and 7 are filled with contents of NUMBERS1, NUMBERS2, and NUMBERS3, respectively. Then the series of three LNR instructions place the twos complement form of the three full words in registers 5, 6, and 7 back into themselves.

Register 5 before execution of the LNR instruction:
\begin{tabular}{|c|c|c|c|c|c|c|c|}
\hline 0000, & 0000 & 0000 & 0000 & 0000, & 0000 & 0000 & 0100 \\
\hline 0 & 0 & 0 & 0 & 0 & 0 & 0 & 4 \\
\hline
\end{tabular}
binary
hex

Register 6 before execution of LNR instruction:


Register 7 before execution of LNR instruction:

binary
hex

Register 5 after execution of LNR instruction:
\begin{tabular}{|c|c|c|c|c|c|c|c|}
\hline \begin{tabular}{c|c|c|c|c|c|c|}
\hline 1111 \\
I 1111
\end{tabular} & \(1111 \mid 1111\) & \(1111 \mid 1111\) & \(1111 / 1100\) \\
\hline F & \(F\) & \(F\) & \(F\) & \(F\) & \(F\) & \(F\) & \(C\) \\
\hline
\end{tabular}
binary
hex

Register 6 after execution of LNR instruction:

binary
hex

Register 7 after execution of LNR instruction:

binary
hex

\subsection*{14.2.4. Load Positive (LPR)}
\begin{tabular}{|c|c|c|c|}
\hline \multicolumn{4}{|c|}{ General } \\
\hline \multicolumn{2}{|c|}{ OPCODE } & FORMAT & \begin{tabular}{l} 
OBJECT \\
INST. \\
TYPE \\
LGTH. \\
(BYTES)
\end{tabular} \\
\hline MNEM. & HEX. & & \begin{tabular}{c} 
RPA
\end{tabular} \\
\hline LPR & \(\mathbf{1 0}\) & RR & 2 \\
\hline
\end{tabular}

Condition Codes
TIF RESULT \(=\) O, SET TO O
IF RESULT \(<0\), SET TO 1
- if result >o, SET TO 2
-IF OVERFLOW, SET TO 3
UNCHANGED
\begin{tabular}{|c|c|}
\hline \multicolumn{2}{|r|}{Possible Program Exceptions} \\
\hline ADDRESSING
data (invalid sign/digit)
decimal divide
decimal overflow
EXECUTE
EXPONENT OVERFLOW
Exponent underflow
fixed-point divide
FIXED-POINT OVERFLOW
floating-point divide
operation & \begin{tabular}{l}
PROTECTION
SIGNIFICANCE
SPECIFICATION:
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 OP 2 NOT ON DOUBLE-WORD BOUNDARY \\
OP 1 NOT EVEN NUMBERED REGISTER op 1 NOT ODD NUMBERED REGISTER none
\end{tabular} \\
\hline
\end{tabular}

The load positive (LPR) instruction places the positive value of the content of the operand 2 register in the operand 1 register. If operand 2 contains a positive value or zero, that same value is placed unchanged in operand 1 . If operand 2 contains a negative number, the twos complement of that number (its positive value) is loaded into operand 1.

Explicit and Implicit Format:
\begin{tabular}{c|l|ll} 
LABEL & \(\triangle\) OPERATION \(\triangle\) & & OPERAND \\
\hline [symbol] & LPR & \(r_{1}, r_{2}\)
\end{tabular}

\section*{Operational Considerations:}
- Any of the general registers ( 0 through 15 ) can be used as operand 1 and 2.
- The maximum negative value you can specify in operand 2 is \(-2,147,483,657\) \(\left(-2^{31}-1\right)\). Otherwise, a fixed-point overflow program exception occurs.
- Operand 2 is not changed by the execution of the instruction.
- The LPR instruction is a featured instruction. An operation program exception is caused if you use this instruction and your processor does not have the control feature.

\section*{Example:}


In this example, registers 5,6 , and 7 are filled with the contents of NUMBERS1, NUMBERS2, and NUMBERS3, respectively. Then the series of three LPR instructions place the twos complement form of the three full words in registers 5, 6, and 7 back into themselves. The result is their positive values.

Register 5 before execution of LPR instruction:

binary
hex

Register 6 before execution of LPR instruction:


Register 7 before execution of LPR instruction:

binary
hex

Register 5 after execution of LPR instruction:


Register 6 after execution of LPR instruction:
\begin{tabular}{|c|c|c|c|c|c|c|c|}
\hline 0000,0000 & 0000 & 0000 & 00001 & 0000 & 0000,0101 \\
\hline 0 & 0 & 0 & 0 & 0 & 0 & 0 & 5 \\
\hline
\end{tabular}
binary
hex

Register 7 after execution of LPR instruction:

binary
hex

\subsection*{14.2.5. Multiply (MR)}
\begin{tabular}{|c|c|c|c|}
\hline \multicolumn{4}{|c|}{General} \\
\hline \multicolumn{2}{|l|}{opcode} & \multirow{2}{*}{FORMAT
TYPE} & \multirow[t]{2}{*}{object INST. LGTH. (BYTES} \\
\hline MNEM. & HEX. & & \\
\hline MR & 1C & RR & 2 \\
\hline \multicolumn{4}{|c|}{Condition Codes} \\
\hline \multicolumn{4}{|l|}{If RESULT \(=0\), SET TO 0 if result <o, set to 1 if Result \(>0\) oset to 2 if overflow, set to 3 unchanged} \\
\hline
\end{tabular}
\begin{tabular}{|c|c|}
\hline \multicolumn{2}{|r|}{Possible Program Exceptions} \\
\hline ADDRESSING
DATA (INVALIDSIGN/DIGIT)
DECIMAL DIVIDE
DECIMAL OVERFLOW
EXECUTE
EXPONENT OVERFLOW
EXPONENT UNDERFLOW
FIXED-POINT DIVIDE
FIXED-POINT OVERFLOW
FLOATING-POINT QIVIDE
OPERATION & \begin{tabular}{l}
PROTECTION
SIGNIFICANCE \\
SPECIFICATION: \\
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 OP 2 NOT ON DOUBLE-WORD BOUNDARY \\
OP 1 NOT EVEN NUMBERED REGISTER OP 1 NOT ODD NUMBERED REGISTER NONE
\end{tabular} \\
\hline
\end{tabular}

The multiply (MR) instruction algebraically multiplies the content of the operand 1 register pair (multiplicand) by the content of the operand 2 register (multiplier). The result (product) is placed in operand 1.

Explicit and Implicit Format:
\begin{tabular}{c|l|l} 
LABEL & DOPERATION \(\triangle\) & \\
\hline [symbol \(]\) & MR & OPERAND \\
\hline
\end{tabular}

\section*{Operational Considerations:}
- Operand 1 consists of a pair of even-odd registers ( 64 bits). You must specify the even-numbered register as operand 1, and you must load the odd-numbered operand 1 register with the multiplicand before using this instruction.
- The product fills the odd-numbered register first and then, if necessary, the evennumbered register.
- Any of the general registers ( 0 through 15 ) can be used as operands 1 and 2. Operand 2 is not changed by the execution of this instruction.
- The MR instruction is a featured instruction. An operation program exception is caused if you use this instruction and your processor does not have the control feature.

Example:
\begin{tabular}{|c|c|c|c|}
\hline LAbEL & \multicolumn{2}{|l|}{\(\triangle O P E R A T I O N \triangle\)} & OPERAND \\
\hline 1 & 10 & 16 & \\
\hline & LH & 8,PRICE & \\
\hline & L.H & 7,NEWBUY & \\
\hline & MR & 6,8 & \\
\hline & - & & \\
\hline & - & & \\
\hline & DC & & \\
\hline NEWBUY & DC & \(\mathrm{H}^{\prime} 731\) & \\
\hline PRICE & DC & \(\mathrm{H}^{\prime} 18 \mathrm{l}\) & \\
\hline
\end{tabular}

In this example, place the contents NEWBUY and PRICE into registers 7 and 8, respectively. Then, multiply the content of the even-odd register-pair 6 and 7 by register 8. (You address the pair of registers by using register 6.) The result is placed in register 7. If, however, the result of the multiplication exceeds the capacity of register 7, register 6 is filled with the remainder of the result.

Registers 6 and 7 before execution:


Register 8 before execution:


Registers 6 and 7 after execution:

14.2.6. Multiply Half Word (MH)
\begin{tabular}{|c|c|c|c|c|c|}
\hline \multicolumn{4}{|c|}{General} & \multicolumn{2}{|r|}{Possible Program Exceptions} \\
\hline \multicolumn{2}{|l|}{OPCODE} & \multirow[t]{2}{*}{\[
\begin{aligned}
& \text { FORMAT } \\
& \text { TYPE }
\end{aligned}
\]} & \multirow[t]{2}{*}{\begin{tabular}{l}
OBJECT \\
INST. \\
LGTH. \\
(BYTES)
\end{tabular}} & \multirow[t]{5}{*}{ADDRESSING
DATA (INVALID SIGN/DIGIT)
DECIMAL DIVIDE
DECIMAL OVERFLOW
EXECUTE
EXPONENT OVERFLOW
EXPONENT UNDERFLOW
FIXED-POINT DIVIDE
FIXED-POINT OVERFLOW
FLOATING-POINT DIVIDE
OPERATION} & \multirow[t]{5}{*}{\begin{tabular}{l}
PROTECTION
SIGNIFICANCE \\
SPECIFICATION: \\
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 \\
OP 2 NOT ON DOUBLE-WORD \\
BOUNDARY \\
OP 1 NOT EVEN NUMBERED REGISTER \\
OP 1 NOT ODD NUMBERED REGISTER \\
NONE
\end{tabular}} \\
\hline MNEM. & HEX. & & & & \\
\hline MH & 4C & RX & 4 & & \\
\hline \multicolumn{4}{|c|}{Condition Codes} & & \\
\hline \multicolumn{4}{|l|}{\(\square\) IF RESULT \(=0\), SET TO O
IF RESULT < O, SET TO 1
\(\square\) IF RESULT \(>0\), SET TO 2
\(\square\) IF OVERFLOW, SET TO 3 UNCHANGED} & & \\
\hline
\end{tabular}

The multiply half word \((\mathrm{MH})\) instruction algebraically multiplies the content of the operand 1 register by the half word operand 2 . The result is placed in the operand 1 register.

\section*{Explicit Format:}
\begin{tabular}{c|c|l} 
LABEL & \(\triangle\) OPERATION \(\triangle\) & \\
\hline [symbol] & MH & \(\mathrm{r}_{1}, \mathrm{~d}_{2}\left(\mathrm{x}_{2}, \mathrm{~b}_{2}\right)\)
\end{tabular}

Implicit Format:
\begin{tabular}{c|c|c} 
LABEL & \(\triangle\) OPERATION \(\triangle\) & \\
\hline [symbol] & MH & \(r_{1}, \mathrm{~s}_{\mathbf{2}}\left(\mathrm{x}_{\mathbf{2}}\right)\)
\end{tabular}

Operational Considerations:
- Any of the general registers ( 0 through 15 ) can be used as operand 1.
- Before execution of the MH instruction, operand 2 is expanded from 16 to 32 bits. The 16 high order bits are propagated with the sign bit value. The contents of operand 2 before the 16 -high order bits are propagated with the sign bit value.


The contents of operand 2 after the 16 high order bits are propagated with the sign bit value.


Operand 2 is not permanently changed by the execution of the instruction.
- The result (product) fills the 32 -bit operand 1 register from right to left. If the product does not fit into the operand 1 field, extra leftmost bits are truncated and the result or sign may be incorrect.
- The MH instruction is a featured instruction. An operation program exception is caused if you use this instruction and your processor does not have the control feature.

\section*{Example:}
\begin{tabular}{|c|c|c|}
\hline LABEL & \multicolumn{2}{|l|}{\(\triangle\) OPERATIONA} \\
\hline 1 & 10 & 16 \\
\hline & L & 7,NEWBUY \\
\hline & MH & 7,PRICE \\
\hline & - & \\
\hline & - & \\
\hline NEWBUY & DC & \(F^{\prime} 7{ }^{\prime}\) \\
\hline PRICE & DC & H'10' \\
\hline
\end{tabular}

In this example, load the contents NEWBUY into register 7 and multiply the halfword of PRICE by the content of register 7. The product is placed in register 7.

Register 7 before execution of MH instruction:
\begin{tabular}{|c|c|c|c|c|c|c|c|}
\hline 0000 & 0000 & 0000 & 0000 & 0000 & 0000 & 0100 & 1001 \\
\hline 0 & 0 & 0 & 0 & 0 & 0 & 4 & 9 \\
\hline
\end{tabular} binary

PRICE before and after execution of MH instruction:


Register 7 after execution of MH instruction:


\section*{SLDA}

\subsection*{14.2.7. Shift Left Double (SLDA)}


The shift left double (SLDA) instruction shifts all of the 63 bits of the operand 1 even-odd register pair to the left the number of bits specified by the low order six bits of the operand 2 address.

\section*{Explicit Format:}
\begin{tabular}{l|l|l} 
LABEL & \(\triangle\) OPERATION \(\triangle\) & \\
\hline [symbol] & SLDA & \(r_{1}, d_{2}\left(b_{2}\right)\)
\end{tabular}

Implicit Format:
\begin{tabular}{c|l|l} 
LABEL & \(\triangle\) OPERATION \(\triangle\) & \\
\hline [symbol] & SLDA & \(r_{1}, s_{2}\)
\end{tabular}

Operational Considerations:
- Any pair of general registers ( 0 through 15) can be used as operand 1 . Operand 1 is an even-odd-numbered register pair. You must specify the even-numbered register of the pair as operand 1.
- The main storage address or label you specify in operand 2 is not changed by the SLDA instruction execution. Notice the formats indicate that you cannot specify a length in operand 2.
- The sign bit (leftmost bit) of the even-numbered operand 1 register pair is not moved or changed by the execution of this instruction. Only the 63 remaining bits can be shifted by this instruction.
- After the requested number of bits are shifted out of the operand 1 register pair, zeros fill the rightmost bit positions of the register pair that were emptied.
- During the instruction execution, each bit being shifted out is checked when it is the bit adjacent to the sign bit. If the bit differs from the sign, it cannot be shifted out without causing a fixed-point overflow program exception.

Before shifting two bits left:


Shifting left three bits in this register pair causes a fixed-point overflow program exception, since the third bit being shifted is not the same value as the sign bit. In this example, two bits are successfully shifted out, but when the third bit is moved adjacent to the sign bit and tested, it is not like the sign.
- Each time you shift one digit left, it is the same as multiplying by a power of 2 . If you shift one bit left, you multiply by 2 , two bits left, you multiply by \(2^{2}\), three bits by \(2^{3}\), and so forth.
- When the shift value is zero, it causes a double-length sign and magnitude test, and the condition code is set.
- The SLDA instruction is a featured instruction. An operation program exception is caused if you use this instruction and your processor does not have the control feature.

Example:
\begin{tabular}{lll} 
LABEL & IOPERATIONA \\
10 & 16 & OPERAND
\end{tabular}
\begin{tabular}{|c|c|c|}
\hline & L & 9, FULLWORD \\
\hline & SLDA & 8,4 \\
\hline & - & \\
\hline & - & \\
\hline FULLWORD & \({ }_{\text {D }}\) & F'4543' \\
\hline
\end{tabular}

In this example, registers 8 and 9 are shifted four bit positions left. Before the SLDA instruction, the content of FULLWORD is placed into register 9. Operand 2 is expressed in explicit format with 4 as the displacement \(\left(d_{2}\right)\) and no base register ( \(b_{2}\) ) representation. Consequently, the addition of base register and displacement values is not performed by the assembler and the operand 2 displacement value becomes the absolute value.

Before execution of SLDA instruction:


Note that the content of register 9 before the shift is 4543 , and after shifting four bits left, it contains 72,688 ( 4543 multiplied by \(2^{4}(16)\) ).

\subsection*{14.2.8. Shift Left Single (SLA)}
\begin{tabular}{|c|c|c|c|}
\hline \multicolumn{4}{|c|}{General} \\
\hline \multicolumn{2}{|l|}{OPCODE} & \multirow{2}{*}{FORMAT TYPE} & \multirow[t]{2}{*}{\begin{tabular}{l}
OBJECT \\
INST. \\
LGTH. \\
(BYTES)
\end{tabular}} \\
\hline MNEM. & HEX. & & \\
\hline SLA & 8 B & RS & 4 \\
\hline \multicolumn{4}{|c|}{Condition Codes} \\
\hline \multicolumn{4}{|l|}{IF RESULT \(=0\), SET TO O IF RESULT < O, SET TO 1 IF RESULT \(>0\), SET TO 2 IF OVERFLOW, SET TO 3 UNCHANGED} \\
\hline
\end{tabular}
\begin{tabular}{|l|l|}
\hline \multicolumn{2}{|c|}{ Possible Program Exceptions } \\
\hline\(\square\) ADDRESSING & \(\square\) PROTECTION \\
\(\square\) DATA (INVALID SIGNIDIGIT) & \(\square\) SIGNIFICANCE \\
\(\square\) DECIMAL DIVIDE & \(\square\) SPECIFICATION: \\
\(\square\) DECIMAL OVERFLOW & \(\square\) NOT A FLOATING-POINT REGISTER \\
\(\square\) EXECUTE & \(\square\) OP 1 NOT ON HALF-WORD BOUNDARY \\
\(\square\) EXPONENT OVERFLOW & \(\square\) OP 2 NOT ON HALF-WORD BOUNDARY \\
\(\square\) EXPONENT UNDERFLOW & \(\square\) OP 2 NOT ON FULL-WORD BOUNDARY \\
\(\square\) FIXED-POINT DIVIDE & \(\square\) OP 2 NOT ON DOUBLE-WORD \\
\(\square\) FIXED-POINT OVERFLOW & \(\square\) BOUNDARY \\
\(\square\) FLOATING-POINT DIVIDE & \(\square\) OP 1 NOTEVEN NUMBEREDREGISTER \\
\(\square\) OPERATION & \(\square\) OP 1 NOT ODD NUMBERED REGISTER \\
& \(\square\) NONE \\
\hline
\end{tabular}

The shift left single (SLA) instruction shifts the 31 bits of the operand 1 register to the left of the number of bits specified by the low order six bits of the operand 2 address. The sign bit (the leftmost high order bit) of register 1 remains unchanged, and zeros fill the vacated positions of the register.

\section*{Explicit Format:}
\begin{tabular}{c|c|l} 
LABEL & \(\triangle\) OPERATION \(\triangle\) & \\
\hline [symbol] & SLA & \(r_{1}, d_{2}\left(b_{2}\right)\)
\end{tabular}

Implicit Format:
\begin{tabular}{c|c|c} 
LABEL & \(\triangle\) OPERATION \(\triangle\) & OPERAND \\
\hline [symbol] & SLA & \(r_{1}, s_{2}\)
\end{tabular}

\section*{Operational Considerations:}
- Any of the general registers ( 0 through 15 ) can be used as operand 1.
- The main storage address or label you specify in operand 2 is not changed by the SLA instruction execution. Notice the formats indicate that you cannot specify a length in operand 2.
- The sign bit (leftmost bit) of the operand 1 register is not shifted or changed by the execution of this instruction. Only the 31 remaining bits can be shifted by the execution of this instruction.
- After the requested number of bits are shifted out of the operand 1 register, zeros fill the vacated rightmost bit positions.
- During the instruction execution, each bit being shifted out is checked when it is the bit adjacent to the sign bit. If the bit differs from the sign, it cannot be shifted out without causing a fixed-point overflow program exception.

Before shifting two bits left:


Shifting left three bits in this register causes a fixed-point overflow program exception, since the third bit being shifted is not the same value as the sign bit. In this example, two bits are successfully shifted out, but when the third bit is moved adjacent to the sign bit and tested, it is not like the sign.
- For numbers with a value of less than \(2^{30}(1,073,741,824)\), each time you shift one digit left, it is the same as multiplying by a power of 2 . If you shift one bit left, you multiply by \(2^{1}\); two bits left, you multiply by \(2^{2}\); three bits by \(2^{3}\); and so forth.
- The SLA instruction is a featured instruction. An operation exception is caused if you use this instruction and your processor does not have the control feature.

\section*{Example:}
\begin{tabular}{lll} 
LABEL & \(\triangle O P E R A T I O N \Delta\) & OPERAND \\
1 & 10 & 16
\end{tabular}


In this example, the content of main storage location FULLWORD is placed in register 8. Register 8 is then shifted one bit position left.

Register 8 before execution of SLA instruction:


Note that register 8 contains 4543 before the SLA instruction and 9086 afterwards. By shifting one bit left, the content of register 8 is multiplied by 2.

\section*{SRDA}

\subsection*{14.2.9. Shift Right Double (SRDA)}


The shift right double (SRDA) instruction shifts the 63 bits of operand 1 to the right the number of bits specified by the low order six bits of the operand 2 address. You cannot shift the sign bit. Specify the even-numbered register of the pair as operand 1.

\section*{Explicit Format:}
\begin{tabular}{l|l|l} 
LABEL & \(\triangle\) OPERATION \(\triangle\) & \\
\hline [symbol] & SRDA & \(r_{1}, \mathrm{~d}_{\mathbf{2}}\left(\mathrm{b}_{2}\right)\)
\end{tabular}

Implicit Format:
\begin{tabular}{c|l|l} 
LABEL & \(\triangle\) OPERATION \(\triangle\) & \\
\hline [symbol] & SRDA & \(\mathrm{r}_{1}, \mathrm{~s}_{2}\)
\end{tabular}

Operational Considerations:
- Any pair of general registers ( 0 through 15 ) can be used as operand 1 , which is an even-numbered register pair. You must specify the even-numbered register of the pair as operand 1.
- The main storage address or label you specify in operand 2 is not changed by the SRDA instruction execution. Notice the formats indicate that you cannot specify a length in operand 2.
- The sign bit (leftmost bit) of the even-numbered operand 1 register pair is not moved or changed by the execution of this instruction. Only the 63 remaining bits can be shifted by this instruction.
- After the requested number of bits are shifted-out of the operand 1 register pair, the vacated leftmost bit positions are filled with bits that have the same value as the sign bit.
- For positive values, each time you shift one bit position right, it is the same as dividing by a power of 2 . If you shift one bit right, you divide by \(2^{1}\); two bits right, you divide by \(2^{2}\); three bits by \(2^{3}\); and so forth. When the value is negative, shifting right causes a divide by 2 on a value one less than the value in the register. For examples, see SRA instruction.
- When the shift value is zero, it causes a double-length sign and magnitude test, and the condition code is set.
- The SRDA instruction is a featured instruction. An operation program exception is caused if you use this instruction and your processor does not have the control feature.

Example:
\begin{tabular}{|c|c|c|c|}
\hline LABEL & \multicolumn{2}{|l|}{\(\triangle\) OPERATIOND} & OPERAND \\
\hline 1 & 10 & 16 & \\
\hline & L & 9, FULLWORD & \\
\hline & SRDA & 8,4 & \\
\hline & - & & \\
\hline & - & & \\
\hline FULLWORD & DC & \(F^{\prime} 72688{ }^{\prime}\) & \\
\hline
\end{tabular}

In this example, registers 8 and 9 are shifted four bit positions right. Before the SRDA instruction, the contents of FULLWORD are placed into register 9.

Before SRDA instruction execution:


Notice that the contents of register 9 before the shift are 72,688 , and after shifting four bits right, it contains 4543 ( 72,688 divided by \(2^{4}(16)\) ).
14.2.10. Shift Right Single (SRA)


The shift right single (SRA) instruction shifts the 31 bits of the operand 1 register to the right the number of bits specified by the low order six bits of the operand 2 address. You cannot shift the sign bit.

Explicit Format:
\begin{tabular}{l|l|l} 
LABEL & \(\triangle\) OPERATION \(\triangle\) & \\
\hline [symbol] & SRA & \(r_{1}, d_{2}\left(b_{2}\right)\)
\end{tabular}

Implicit Format:
\begin{tabular}{l|l|l} 
LABEL & \(\triangle\) OPERATION \(\Delta\) & \\
\hline [symbol] & SRA & \(r_{1}, s_{2}\)
\end{tabular}

\section*{Operational Considerations:}
- Any of the general registers ( 0 through 15 ) can be used as operand 1.
- The main storage address or label you specify in operand 2 is not changed by the SRA instruction execution. Notice the formats indicate that you cannot specify a length in operand 2.
- The sign bit (leftmost bit) of the operand 1 register is not shifted or changed by the execution of this instruction. Only the 31 remaining bits can be shifted by the execution of this instruction.

After the requested number of bits are shifted out of the operand 1 register, the vacated leftmost bits are filled with bits that have the same value as the sign bit.
- If the contents of the operand 1 register are a positive value, shifting right one bit divides the value of the register by 2 . Any remainders are rounded downward. For example, a value of +5 shifted right one bit produces a +2 in the register after the shift.

Before one bit shift right:


When contents of the operand 1 register are negative, shifting right one bit causes a divide by 2 on a value one less than the value in the operand 1 register. For example, a value of -5 , when shifted right one bit produces a - 3 in the register ( -6 divided by 2 ).

Before one bit shift right:


Note that a negative is expressed in twos complement notation. After the shifting operation, you can determine the positive value in the register by taking the twos complement of a negative number.

- The SRA instruction is a featured instruction. An operation program exception is caused if you use this instruction and your processor does not have the control feature.

Example:
\(\begin{array}{lll}\text { LABEL } & \triangle O P E R A T I O N \Delta & \text { OPERAND } \\ 1 & 10 & 16\end{array}\)
\begin{tabular}{cl}
\hline & \\
L & 8, FULLWORD \\
SRA & 8,1 \\
\(\bullet\) & \\
FULLWORD & \\
DC & \(\mathrm{F}^{\prime} 4543^{\prime}\)
\end{tabular}

In this example, the content of main storage location FULLWORD is placed in register 8. Register 8 is then shifted one bit position right.

Register 8 before SRA instruction execution:


Note that register 8 contains 4543 before the SRA instruction and 2271 afterwards. By shifting one bit right, the content of register 8 is divided by 2.

\subsection*{14.3. FEATURED LOGICAL INSTRUCTIONS}

The featured logical instructions are described in 14.3.1 through 14.3.7. (See Section 12 for descriptions of the remaining logical instructions.)

AL

\subsection*{14.3.1. Add Logical (AL)}


The add logical (AL) instruction logically adds the content of operand 2 to the content of the operand 1 register and places the sum in operand 1.

\section*{Explicit Format:}
\begin{tabular}{c|l|l} 
LABEL & \(\triangle\) OPERATION \(\Delta\) & OPERAND \\
\hline [symbol] & \(A L\) & \(r_{1}, d_{2}\left(x_{2}, b_{2}\right)\)
\end{tabular}

Implicit Format:
\begin{tabular}{c|l|l} 
LABEL & DOPERATION \(\Delta\) & \\
\hline [symbol] & AL & \(\mathrm{r}_{1}, \mathrm{~s}_{2}\left(\mathrm{x}_{2}\right)\)
\end{tabular}

Operational Considerations:
- Any of the general registers ( 0 through 15 ) can be used as operand 1.
- The main storage location you specify in operand 2 must refer to a main storage area that is on a full-word boundary. Operand 2 is not changed by the execution of this instruction.
- The addition is performed by logically adding the 32 bits of operand 2 to the 32 bits of operand 1.
- Neither operand has a sign bit.
- The condition code of the program status word (PSW) is set as follows:
- to 0 if result is 0 (no carry of most significant bit);
- to 1 if result is not 0 (no carry of most significant bit);
- to 2 if result is 0 (carry of most significant bit); or
- to 3 if result is not 0 (carry of most significant bit).
- The AL instruction is a featured instruction. An operation program exception is caused if you use this instruction and your processor does not have the control feature.

Example:
\begin{tabular}{lll} 
LABEL & \(\triangle O P E R A T I O N \Delta\) & OPERAND \\
1 & 10 & 16
\end{tabular}

In this example, the main storage content of HEXVALU is placed into register 3. The AL instruction logically adds the full-word content of main storage location FULLWORD to the content of register 3 and places the sum in register 3 .

Register 3 before execution of AL instruction:


FULLWORD before execution of AL instruction:
\begin{tabular}{|c|c|c|c|c|c|c|c|}
\hline 0000 & 0000 & 0000 & 0000 & 0000 & 0111 & 1001 & 1100 \\
\hline 0 & 0 & 0 & 0 & 0 & 7 & 9 & \(C\) \\
binary \\
\hline
\end{tabular}

Register 3 after execution of AL instruction:


\subsection*{14.3.2. Add Logical (ALR)}
\begin{tabular}{|c|c|c|c|c|c|}
\hline \multicolumn{4}{|c|}{General} & \multicolumn{2}{|r|}{Possible Program Exceptions} \\
\hline \multicolumn{2}{|l|}{OPCODE} & \multirow[t]{2}{*}{FORMAT
TYPE} & \multirow[t]{2}{*}{OBJECT INST. LGTH. (BYTES)} & \multirow[t]{5}{*}{addressing
data (invalid sign/digit)
decimal divide
decimal overflow
Execute
EXPONENT OVERFLOW
Exponent underflow
FIXED-POINT DIVIDE
Fixed-point overflow
floating-point divide
operation} & \multirow[t]{5}{*}{\begin{tabular}{l}
PROTECTION
significance
SPECIFICATION: \\
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 \\
OP 2 NOT ON DOUBLE-WORD \\
BOUNDARY \\
OP 1 NOT EVEN NUMBERED REGISTER \\
op 1 NOT ODD NUMBERED REGISTER \\
NONE
\end{tabular}} \\
\hline MNEM. & HEX. & & & & \\
\hline ALR & 1E & RR & 2 & & \\
\hline \multicolumn{4}{|c|}{Condition Codes} & & \\
\hline \multicolumn{4}{|l|}{SET TO O
SET TO 1
SETTO 2
SET TO 3
SEE OPER. CONSIDERATIONS} & & \\
\hline
\end{tabular}

The add logical (ALR) instruction logically adds the content of the operand 1 register to the content of the operand 2 register and places the sum in operand 1.

Explicit and Implicit Format:
\begin{tabular}{c|c|c} 
LABEL & DOPERATION \(\triangle\) & \\
\hline [symbol] & ALR & \(r_{1}, r_{2}\)
\end{tabular}

\section*{Operational Considerations:}
- Any of the general registers (0 through 15) can be used as operands 1 and 2.
- The addition is performed by logically adding the 32 bits of operand 2 to operand 1 .
- Neither operand has a sign bit.
- The condition code of the program status word (PSW) is set as follows:
- to 0 if result is 0 (no carry of most significant bit);
- to 1 if result is not 0 (no carry of most significant bit);
- to 2 if result is 0 (carry of most significant bit); or
- to 3 if result is not 0 (carry of most significant bit).
- The ALR instruction is a featured instruction. An operation program exception is caused if you use this instruction and your processor does not have the control feature installed.

\section*{Example:}
```

LABEL \triangleOPERATION\triangle OPERAND
1 10 16

```
\begin{tabular}{ll} 
L & 3,VALU1 \\
L & 4,VALU2 \\
ALR & 3,4
\end{tabular}
VALUI DC X'øøбøøø19'
VALU2 DC X'øøббø79C'

In this example, the hexadecimal contents of main storage locations VALU1 and VALU2 are placed in registers 3 and 4, respectively. Then, the contents of registers 3 and 4 are added and the sum placed in register 3.

Register 3 before execution of ALR instruction:

binary
hex

Register 4 before execution of ALR instruction:

binary
hex

Register 3 after execution of ALR instruction:

binary
hex

\section*{EDMK}

\subsection*{14.3.3. Edit And Mark (EDMK)}


The edit and mark (EDMK) instruction operates like the edit (ED) instruction except that it also saves the address of the first significant byte and places it in register 1.

\section*{Explicit Format:}
\begin{tabular}{l|l|l} 
LABEL & DOPERATION \(\Delta\) & OPERAND \\
\hline [symbol] & EDMK & \(d_{1}\left(1, b_{1}\right), d_{2}\left(b_{2}\right)\)
\end{tabular}

Implicit Format:
\begin{tabular}{c|c|l} 
LABEL & DOPERATION \(\triangle\) & \\
\hline [symbol] & EDMK & \(\mathrm{s}_{1}(\mathrm{l}), \mathrm{s}_{2}\)
\end{tabular}

\section*{Operational Considerations:}
- The EDMK instruction operates like the ED instruction (see 9.6). After the packed content of operand 2 is edited and the unpacked result stored in operand 1, the address of the first nonzero character is placed in general register 1.
- The condition code is set in the same manner as the ED instruction.
- If the field to be edited contains no significant digits until after the significance starter, no address is moved into register 1, and the move instruction following the EDMK instruction will be using the incorrect address (or whatever value) that is in register 1.
- To avoid having an incorrect address in register 1 because no significant digits exist before the significance starter, load register 1 with the address of the position where you want the insert character to be placed.
- If a field to be edited contains multiple fields, the address of the first significant byte in each field replaces the one before. So in effect, the address of the first significant byte in the last field is the final result.
- The EDMK instruction is a featured instruction. An operation program exception is caused if you use this instruction and the processor does not have the control feature installed.
- This instruction is used to insert a character in several places throughout the output display. For example:
\$6.25
\$86.00
\$2.34
\$724.11
The location of the dollar sign is predicatable in that it appears at the left of the first significant digit on each line. The decimal point position also is predictable as the third character from the right. The proper positioning of a dollar sign or other message character is ensured by using the EDMK instruction.

Example:
\begin{tabular}{|c|c|c|c|}
\hline \multirow[t]{2}{*}{\[
\begin{aligned}
& \text { LABEL } \\
& 1
\end{aligned}
\]} & \multicolumn{2}{|l|}{\(\triangle O P E R A T I O N \triangle\)} & \multirow[t]{2}{*}{OPERAND} \\
\hline & 10 & 16 & \\
\hline & MVC & PATTERN,MASK & \\
\hline & LA & 1,PATTERN+7 & \\
\hline & EDMK & PATTERN, DATA & \\
\hline & S & 1,=F'1' & \\
\hline & MVI & (1) , C'\$' & \\
\hline & - & & \\
\hline & & & \\
\hline PATTERN & DS & CLID & \\
\hline MASK & DC & X'4ø2ø2ø6B2ø2ø21482ø2ø & \\
\hline DATA & DC & P'0245710' & \\
\hline
\end{tabular}

Register 1 before execution of EDMK instruction:


Register 1 after execution of EDMK instruction:


Register 1 after execution of \(S\) instruction:


Edited result after execution of MVI instruction:


In this example, the edit mask is moved into a 10-byte field labeled PATTERN. The address of the position where the insert character is to be placed (in the absence of significant digits before the significance starter) is loaded into register 1. Then DATA, containing the packed number, is edited and the result is placed in PATTERN. The address of the first significant byte (in this example, 2 is significant) replaces the content of register 1 . Then a full word containing the decimal value 1 is subtracted from the content of register 1, therefore moving one byte to the left. The MVI instruction moves the dollar sign into the byte addressed by the content of register 1.

\section*{SLDL}

\subsection*{14.3.4. Shift Left Double Logical (SLDL)}

\begin{tabular}{|c|c|}
\hline \multicolumn{2}{|r|}{Possible Program Exceptions} \\
\hline ADDRESSING
DATA (INVALIDSIGN/DIGIT)
DECIMAL DIVIDE
DECIMAL OVERFLOW
EXECUTE
EXPONENT OVERFLOW
EXPONENT UNDERFLOW
FIXED-POINT DIVIDE
FIXED-POINT OVERFLOW
FLOATING-POINT DIVIDE
OPERATION & \begin{tabular}{l}
PROTECTION
SIGNIFICANCE
SPECIFICATION: \\
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 OP 2 NOT ON DOUBLE-WORD BOUNDARY OP 1 NOT EVEN NUMBERED REGISTER OP 1 NOT ODD NUMBERED REGISTER NONE
\end{tabular} \\
\hline
\end{tabular}

The shift left double logical (SLDL) instruction shifts all of the 63 bits of operand 1 to the left the number of bits specified by the low order six bits of the operand 2 address. Specify the even-numbered register of the pair as operand 1.

\section*{Explicit Format:}
\begin{tabular}{c|l|l} 
LABEL & \(\triangle\) OPERATION \(\Delta\) & \\
\hline [symbol] & SLDL & \(\mathbf{r}_{1}, d_{2}\left(b_{2}\right)\)
\end{tabular}

Implicit Format:
\begin{tabular}{c|c|c} 
LABEL & \(\triangle\) OPERATION \(\Delta\) & OPERAND \\
\hline [symbol] & SLDL & \(r_{1}, s_{2}\)
\end{tabular}

Operational Considerations:
- Any pair of general registers ( 0 through 15 ) can be used as operand 1 , which is an even-odd-numbered register pair. You must specify the even-numbered register of the pair as operand 1.
- The main storage address or label you specify in operand 2 is not changed by the SLDL instruction execution. Notice the formats indicate that you cannot specify a length in operand 2.
- After the requested number of bits are shifted out of the operand 1 register pair, zeros fill the rightmost bit positions of the register pair.
- The SLDL instruction is a featured instruction. An operation program exception is caused if you use this instruction and your processor does not have the control feature.

Example 1:
\begin{tabular}{|c|c|c|c|}
\hline LABEL & \multicolumn{2}{|l|}{\(\triangle\) OPERATIONA} & OPERAND \\
\hline 1 & 10 & 16 & \\
\hline & LM & 4,5, VALUE & \\
\hline & SLDL & 4,32 & \\
\hline & - & & \\
\hline & - & & \\
\hline & - & & \\
\hline & DS & \(\emptyset F\) & \\
\hline value & DC & X'FFFFFFFF' & \\
\hline & DC & X'FFFFFFFF' & \\
\hline
\end{tabular}

In this example, register 4 is loaded with the content of main storage location VALUE. Register 5 is loaded with the next 32 bits of main storage following VALUE. The SLDL instruction causes the contents of the registers to be shifted left 32 bits.

Registers 4 and 5 before execution of SLDL instruction:

hex
binary

Registers 4 and 5 after execution of SLDL instruction:


\section*{Example 2:}

This example using the SLDL has the same shift result except that a label is used as operand 2 of the SLDL instruction.

LABEL \(\triangle\) OPERATIONA 1016
\begin{tabular}{lll}
\hline & LM & 4,5, VALUE \\
& SLDL & 4, STORAGE \\
& \(\vdots\) & \\
& \(\vdots\) & \\
& & \\
VALUE & DS & \(\emptyset F\) \\
STORAGE & & \\
& DCU & \(2 \times 4^{\prime}\) FFFFFFFF'
\end{tabular}

In this example, the absolute value of the main storage location STORAGE determines the number of bits that operand 1 should be shifted left. The operand 2 label is equated (EOU instruction) with a hexadecimal value that indicates how many bit positions you want to move. This is necessary so that the assembler takes the absolute value that you equated with your label and not its relocatable address. Note that a hexadecimal 20 is equivalent to a decimal 32.

Registers 4 and 5 before execution of SLDL instruction:


STORAGE before and after SLDL instruction execution:


Registers 4 and 5 after SLDL instruction execution:


\subsection*{14.3.5. Shift Right Double Logical (SRDL)}
\begin{tabular}{|c|c|c|c|c|c|}
\hline \multicolumn{4}{|c|}{General} & \multicolumn{2}{|r|}{Possible Program Exceptions} \\
\hline \multicolumn{2}{|l|}{OPCODE} & \multirow[t]{2}{*}{FORMAT TYPE} & \multirow[t]{2}{*}{\begin{tabular}{l}
OBJECT INST. \\
LGTH. \\
(BYTES)
\end{tabular}} & \multirow[t]{5}{*}{ADDRESSING
DATA (INVALIDSIGN/DIGIT)
DECIMAL DIVIDE
DECIMAL OVERFLOW
EXECUTE
EXPONENT OVERFLOW
EXPONENT UNDERFLOW
FIXED-POINT DIVIDE
FIXED-POINT OVERFLOW
FLOATING-POINT DIVIDE
OPERATION} & \multirow[t]{5}{*}{\begin{tabular}{l}
PROTECTION
SIGNIFICANCE
SPECIFICATION:
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 \\
OP 2 NOT ON DOUBLE-WORD \\
BOUNDARY \\
OP 1 NOT EVEN NUMBERED REGISTER \\
OP 1 NOT ODD NUMBERED REGISTER
NONE
\end{tabular}} \\
\hline MNEM. & HEX. & & & & \\
\hline SRDL & 8C & RS & 4 & & \\
\hline \multicolumn{4}{|c|}{Condition Codes} & & \\
\hline \multicolumn{4}{|l|}{IF RESULT \(=0\) O, SET TO O IF RESULT<0, SET TO 1 IF RESULT \(>0\) O, SET TO 2 If overflow, set to 3 UNCHANGED} & & \\
\hline
\end{tabular}

The shift right double logical (SRDL) instruction shifts the 64 bits of operand 1 to the right the number of bits specified by the low order six bits of the operand 2 address. You specify the even-numbered register of the pair as operand 1.

\section*{Explicit Format:}
\begin{tabular}{c|l|l} 
LABEL & \(\triangle\) OPERATION \(\triangle\) & \\
\hline [symbol] & SRDL & \(r_{1}, d_{2}\left(b_{2}\right)\)
\end{tabular}

Implicit Format:
\begin{tabular}{c|c|c} 
LABEL & \(\triangle\) OPERATION \(\triangle\) & \\
\hline [symbol] & SRDL & \(r_{1}, s_{2}\)
\end{tabular}

\section*{Operational Considerations:}
- Any pair of the general registers (0 through 15 ) can be used as operand 1. Operand 1 is an even-odd-numbered register pair. You must specify the even-numbered register of the pair as operand 1.
- The main storage address or label you specify in operand 2 is not changed by the SRDL instruction execution. Notice the formats indicate that you cannot specify a length in operand 2.
- After the requested number of bits are shifted out of the operand 1 register pair, 0's fill the leftmost bit positions of the register pair.
- The SRDL instruction is a featured instruction. An operation program exception results if you use this instruction and the processor does not have the control feature.

\section*{Example 1:}
\begin{tabular}{lll} 
LABEL & \(\triangle O P E R A T I O N \Delta\) & OPERAND \\
1 & 10 & 16
\end{tabular}
\begin{tabular}{|c|c|c|}
\hline & LM & 4,5,VALUE \\
\hline & SRDL & 4,32 \\
\hline & - & \\
\hline & - & \\
\hline & DS & \(\emptyset F\) \\
\hline value & DC & 2XL4, 'FFFFFFFF' \\
\hline
\end{tabular}

In this example, registers 4 and 5 are loaded with the content of main storage location VALUE. The SRDL instruction causes the content of a register to be shifted right 32 bits.

Registers 4 and 5 before execution of SRDL instruction:


Registers 4 and 5 after SRDL instruction execution:


\section*{Example 2:}

This example using the SRDL instruction has the same shift result, but a label is used as operand 2 of the SRDL instruction.
\begin{tabular}{|c|c|c|c|}
\hline LABEL & \multicolumn{2}{|l|}{\(\triangle O P E R A T I O N \triangle\)} & OPERAND \\
\hline 1 & 10 & 16 & \\
\hline & LM & 4,5,VALUE & \\
\hline & SRDL & 4, STORAGE & \\
\hline & - & & \\
\hline & \(\dot{\text { D }}\) & \(\emptyset F\) & \\
\hline VALUE & DC & 2XL4'FFFFFFFF' & \\
\hline STORAGE & EQU & \(\chi^{\prime} 2 \varnothing^{\prime}\) & \\
\hline
\end{tabular}

In this example, the absolute value of the main storage location STORAGE determines the number of bits that operand 1 should be shifted right. The operand 2 label is equated (EQU instruction) with a hexadecimal value that indicates how many bit positions you want to move. This is necessary so that the assembler takes the absolute value that you equated with your label and not its relocatable address. Note that a hexadecimal 20 is equivalent to a decimal 32.

Registers 4 and 5 before execution of SRDL instruction:


STORAGE before and after SRDL instruction execution:


Registers 4 and 5 after instruction execution:


\section*{SL}

\subsection*{14.3.6. Subtract Logical (SL)}
\begin{tabular}{|c|c|c|c|c|c|}
\hline \multicolumn{4}{|c|}{General} & \multicolumn{2}{|r|}{Possible Program Exceptions} \\
\hline \multicolumn{2}{|l|}{OPCODE} & \multirow[t]{2}{*}{\[
\begin{gathered}
\text { FORMAT } \\
\text { TYPE }
\end{gathered}
\]} & \multirow[t]{2}{*}{\begin{tabular}{l}
OBJECT \\
INST. \\
LGTH. \\
(BYTES)
\end{tabular}} & \multirow[t]{5}{*}{\begin{tabular}{l}
ADDRESSING
DATA (INVALIDSIGN/DIGIT)
DECIMAL DIVIDE
DECIMAL OVERFLOW
EXECUTE
EXPONENT OVERFLOW
EXPONENT UNDERFLOW
FIXED-POINT DIVIDE
FIXED-POINT OVERFLOW
FLOATING-POINT DIVIDE \\
operation
\end{tabular}} & \multirow[t]{5}{*}{\begin{tabular}{l}
PROTECTION
SIGNIFICANCE
SPECIFICATION:
NOT A FLOATING-POINT REGISTER \\
OP 1 NOT ON HALFWORD BOUNDARY \\
OP 2 NOT ON HALF-WORD BOUNDARY \\
OP 2 NOT ON FULL-WORD BOUNDARY \\
OP 2 NOT ON DOUBLE-WORD \\
BOUNOARY \\
OP 1 NOT EVEN NUMBERED REGISTER \\
OP 1 NOT ODD NUMBERED REGISTER \\
NONE
\end{tabular}} \\
\hline MNEM. & HEX. & & & & \\
\hline SL & 5F & RX & 4 & & \\
\hline \multicolumn{4}{|c|}{Condition Codes} & & \\
\hline \multicolumn{4}{|l|}{\begin{tabular}{l}
SET TO O \\
SET TO 1 \\
SET TO 2 \\
SET TO 3 \\
SEE OPER. CONSIDERATIONS
\end{tabular}} & & \\
\hline
\end{tabular}

The subtract logical (SL) instruction logically subtracts the content of operand 2 from the content of the operand 1 register and places the result in operand 1.

\section*{Explicit Format:}
\begin{tabular}{c|l|l} 
LABEL & \(\triangle\) OPERATION \(\triangle\) & \\
\hline [symbol] & SL & \(\mathrm{r}_{1}, \mathrm{~d}_{2}\left(\mathrm{x}_{2}, \mathrm{~b}_{2}\right)\)
\end{tabular}

Implicit Format:
\begin{tabular}{c|c|l} 
LABEL & \(\triangle\) OPERATION \(\triangle\) & \\
\hline [symbol] & SL & \(\mathrm{r}_{1}, \mathrm{~s}_{2}\left(\mathrm{x}_{2}\right)\)
\end{tabular}

\section*{Operational Considerations:}
- Any of the general registers (0 through 15) can be used as operand 1.
- The label or address you specify in operand 2 must refer to a main storage location that is on a full-word boundary. Operand 2 is not changed by the execution of this instruction.
- The logical subtraction is performed by adding the twos complement of operand 2 to operand 1. All 32 bits of each operand are used.
- Neither operand has a sign bit.
- The condition code of the program status word (PSW) is set as follows:
- to 1 if result is not 0 (no carry of most significant bit);
- to 2 if result is 0 (carry of most significant bit); or
- to 3 if result is not 0 (carry of most significant bit).

Zero code is not used.
- The SL instruction is a featured instruction. An operation program exception is caused if you use this instruction and your processor does not have the control feature.

Example:


In this example, the hexadecimal content of HEXVALU is placed in register 3. Then the twos complement of the content of main storage location FULLWORD is added to the content of register 3.

FULLWORD before twos complement:

hex
binary

Twos complement of FULLWORD:


Register 3 before execution of SL instruction:

hex
binary

Register 3 after execution of SL instruction:

hex
binary

The twos complement of FULLWORD is added to the content of register 3. The result replaces the content of register 3 . The condition code is set to 3 , since the result is not 0 , and there is carryout (leftover 1 bit ) of the leftmost bit. The carryout does not cause an overflow condition as would the subtract (S) instruction.

\subsection*{14.3.7. Subtract Logical (SLR)}
\begin{tabular}{|c|c|c|c|c|c|}
\hline \multicolumn{4}{|c|}{General} & \multicolumn{2}{|r|}{Possible Program Exceptions} \\
\hline \multicolumn{2}{|l|}{opcode} & \multirow[t]{2}{*}{\[
\begin{aligned}
& \text { FORMAT } \\
& \text { TYPE }
\end{aligned}
\]} & \multirow[t]{2}{*}{object INST. LGTH. (BYTES)} & \multirow[t]{5}{*}{ADDRESSING
data (invalid sign/digit)
decimal oivide
decimal overflow
execute
EXPONENT OVERFLOW
Exponent underflow
FIXED-POINT DIVIDE
FIXED-POINT OVERFLOW
floating-point divide
operation} & \multirow[t]{2}{*}{PROTECTION
significance
SPECIFICATION:} \\
\hline MNEM. & HEX. & & & & \\
\hline SLR & 1F & RR & 2 & & \(\square\) OP 1 NOT ON HALF-WORD BOUNDARY \\
\hline \multicolumn{4}{|c|}{Condition Codes} & & \begin{tabular}{l}
\(\square\) OP 2 NOT ON HALF-WORD BOUNDARY \\
\(\square\) OP 2 NOT ON FULL-WORD BOUNDARY
\end{tabular} \\
\hline \multicolumn{4}{|l|}{\begin{tabular}{l}
SET TO 0 \\
SET TO 1 \\
SET TO 2 \\
SET TO 3 \\
SEE OPER. CONSIDERATIONS
\end{tabular}} & & \begin{tabular}{l}
OP 2 NOT ON DOUBLE-WORD \\
BOUNDARY \\
op 1 Not even numbered register \\
op 1 NOT ODD NUMBERED REGISTER
NONE
\end{tabular} \\
\hline
\end{tabular}

The subtract logical (SLR) instruction logically subtracts the content of the operand 2 register from the content of the operand 1 register and places the result in operand 1.

Explicit and Implicit Format:
\begin{tabular}{c|l|l} 
LABEL & \(\triangle\) OPERATION \(\Delta\) & \\
\hline [symbol] & SLR & \(r_{1}, r_{2}\)
\end{tabular}

\section*{Operational Considerations:}
- Any of the general registers ( 0 through 15 ) can be used as operands 1 and 2.
- The logical subtraction is performed by adding the two's complement of operand 2 to operand 1. All 32 bits of each operand are used.
- Neither operand has a sign bit.
- The condition code of the program status word (PSW) is set as follows:
- to 1 if result is not 0 (no carry of most significant bit);
- to 2 if result is 0 (carry of most significant bit); or
- to 3 if result is not 0 (carry of most significant bit).

Zero code is not used.
- The SLR instruction is a featured instruction. An operation program exception is caused if you use this instruction and your processor does not have the control feature.

\section*{Example:}
```

LABEL \triangleOPERATION\triangle OPERAND
10}1

```
            L 3,VALUI
            L 5,VALU2
            SLR \(\quad 3,5\)
            -
            -
            DS
VALUI DC X'øøøøøFF8'
VALU2 DC X'øøøøøEめ8'

In this example, the hexadecimal contents of main storage locations VALU1 and VALU2 are loaded into registers 3 and 5, respectively. Then, the SLR instruction logically subtracts the content of register 5 from the content of register 3.

Register 5 before twos complement:


Twos complement of register 5:


Register 3 before execution of SLR instruction:


Register 3 after execution of SLR instruction:

hex
binary

The twos complement of register 5 is added to the content of register 3. The result replaces the content of register 3. The condition code is set to 3 , since the result is not zero and there is a carryout (leftover 1 bit ) of the leftmost bit. The carryout does not cause an overflow condition as would the subtract (SR) instruction.

\section*{PART 4. BAL DIRECTIVES}


\section*{15. Introduction to Directives}

The OS/3 assembly language includes assembler directives (Table 15-1) that enable the user to control assembler operation. Assembler directives control the assembler at assembly time just as application instructions control the processor at execution time. Housekeeping, program organization, assembly listing modification, and I/O control are the tasks of the directives.

The assembler application instructions the programmer uses to control the processor operation are discussed in Part 3 of this manual. The major portion of the program statements consists of these instructions. Just as there are mnemonics to direct the generation of the instructions, there are directives to control the operation of the software language processor (the assembler). These are called assembler directives.

Table 15-1. Assembler Directives
\begin{tabular}{|l|l|c|}
\hline \multicolumn{1}{|c|}{\begin{tabular}{c} 
Types of \\
Directives
\end{tabular}} & \multicolumn{1}{|c|}{ Basic Function } & \begin{tabular}{c} 
Where \\
Discussed
\end{tabular} \\
\hline \begin{tabular}{l} 
EQUATE \\
OPSYM
\end{tabular} & \begin{tabular}{l} 
Symbol definitions \\
Delete operation code
\end{tabular} & Section 16 \\
\hline \begin{tabular}{l} 
ASSEMBLER \\
CONTROL
\end{tabular} & \begin{tabular}{l} 
Control program name and \\
organization
\end{tabular} & Section 17 \\
\hline \begin{tabular}{l} 
BASE REGISTER \\
ASSIGNMENT
\end{tabular} & \begin{tabular}{l} 
Directs registers to be \\
used and when
\end{tabular} & Section 18 \\
\hline \begin{tabular}{l} 
LINKING AND \\
SECTIONING
\end{tabular} & \begin{tabular}{l} 
Control of modules to be \\
linked
\end{tabular} & Section 19 \\
\hline LISTING CONTROL & Control of the assembly listing & Section 20 \\
\hline I/O CONTROL & Control of input/output data & Section 21 \\
\hline
\end{tabular}

\(\bullet\)

\title{
16. Equate and Delete Operation Code Directives
}

\subsection*{16.1. EQUATE (EQU)}

The equate (EQU) directive defines the length and value of a symbol using another symbol as all or part of the definition.

The format is as follows:
\begin{tabular}{c|l|l} 
LABEL & \(\triangle\) OPERATION \(\Delta\) & \\
\hline symbol & EQU & \(\mathrm{e}[, \mathrm{a}]\)
\end{tabular}
where:
e
Is an absolute or relocatable expression.
a
Is an absolute expression.
All symbols must be predefined.
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 . (See coding examples on following page.)

Examples:
LABEL \(\triangle O P E R A T I O N \triangle\)
\(\begin{array}{lll}10 & 10 & 16\end{array}\)
```

OPERAND

```
```

OPERAND

```

DS
25CL1 10
2. HIDE EQU
\(100+\) TAG,150
3. SEEK EQU
4. GO EQU
5. Rø

EQU
TAG+127ø-*

EQU
\(6 . \mathrm{RI}_{1}\)
\(\emptyset\)
1

If the value of the location counter is 2000 when instructions 1 through 4 are encountered, the symbols have the following location counter values:
1. TAG has a relocatable value of 2000 and a length attribute of 10. The location counter is advanced to 2250.
2. HIDE has a relocatable value of \(2100(100+2000)\) and a length attribute of 150 . The location counter remains at 2250.
3. SEEK has an absolute value of \(1020(2000+1270-2250)\) and a length attribute of 10 (same as length of first term).
4. If line 4 is substituted in place of line 3, then GO has an absolute value of 1020 \((2000+1270-2250)\) and a length attribute of 200 . (The 200 overrides the length of TAG.)
5. The registers 0 and 1 are equated to RO and R1. (See 6.1.) and
6.

\subsection*{16.2. DELETE OPERATION CODE (OPSYM)}

The delete operation code (OPSYM) directive allows you to tell the assembler not to accept a certain mnemonic operation code.

The format is as follows:
\begin{tabular}{l|l|l} 
LABEL & DOPERATION \(\Delta\) & \\
\hline \begin{tabular}{l} 
mnemonic \\
operation \\
code
\end{tabular} & OPSYIM & unused \\
\hline
\end{tabular}

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, for example, as the mnemonic code of a macro prototype statement.

Examples:
\begin{tabular}{lcc} 
LABEL & \(\triangle O P E R A T I O N \triangle\) & OPERAND \\
1 & 10 & 16
\end{tabular}


In this example, the program is preceded by a macro definition which is used 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 code before the line of code which references the macro, that is, line 8 must precede line 9.

The OPSYM directive cannot be used from within a PROC/MACRO or from within code generated as a result of conditional assembly statements.

\section*{17. Assembler Control Directives}

Assembler control directives are available to name the program and specify an initial location counter, section the program, alter the location counter to a specified value, indicate the end of a program, and designate the instruction the program will begin with. Table \(17-1\) is a summary of the assembler control directives available to the user of the OS/3 assembler.

Table 17-1. Assembler Control Directives
\begin{tabular}{|l|l|c|}
\hline Directives & Basic Function & \begin{tabular}{c} 
Where \\
Discussed
\end{tabular} \\
\hline CNOP & Condition no operation & 17.1 \\
\hline END & Program end & 17.2 \\
\hline LTORG & Generate literal pool & 17.3 \\
\hline ORG & Specify location counter & 17.4 \\
\hline START & Program start & 17.5 \\
\hline
\end{tabular}

\section*{CNOP}

\subsection*{17.1. CONDITION NO OPERATION (CNOP)}

The condition no operation (CNOP) directive adjusts the location counter to a half-word, fullword, or double-word storage boundary. The format of the CNOP directive is:
\begin{tabular}{l|l|l} 
LABEL & \(\triangle\) OPERATION \(\Delta\) & \\
\hline unused & CNOP & \(\mathrm{a}_{1}, \mathrm{a}_{2}\)
\end{tabular}
where:
\(\mathbf{a}_{1}\) and \(\mathbf{a}_{2}\)
Are absolute expressions consisting of predefined terms.
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 0 and 2 for full-word boundary alignment, and \(0,2,4\), and 6 for double-word boundary alignment.
- 0 indicates a full-word or double-word boundary;
- 2 indicates the second byte (first half word) past the boundary;
- 4 indicates the fourth byte (second half word) past a double-word boundary; and
- 6 indicates the sixth byte (third half word) past a double-word boundary.

Permissible values for the second expressions 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.

Examples:

\begin{tabular}{lll}
1. & CNOP & \(\emptyset, 8\) \\
2. & CNOP & 2,4
\end{tabular}
1. The current location counter is advanced, if necessary, to the first byte of the next double-word boundary. A legal double-word boundary is any address value divisible by 8 .
2. The current location counter is advanced, if necessary, to the second byte first half word) past the next full-word boundary. A legal full-word boundary is any address value divisible by 4 .

\section*{END}

\subsection*{17.2. PROGRAM END (END)}

The program end (END) directive indicates the end of a source program or macro definition written in PROC format. (See Appendix A and Section 25.)

The format of the END directive is:

where:
e
Is a relocatable expression.
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. If the END directive is missing, an END directive with a blank operand field is supplied by the assembler. If the END directive terminates a proc, the label and operand fields are not used.

Examples:
```

    LABEL \triangleOPERATION\triangle 
    ```
\begin{tabular}{|lll} 
FOX & END & BEGN \\
& END & G0+324
\end{tabular}

All three of the END statements halt assembly, but each transfers control to a different address in the program.
1. Control is transferred to a statement labeled BEGN in the program. The label FOX is assigned the address associated with the last byte of the assembly.
2. If GO has a value of 1000, control is transferred, and the next instruction to be processed is located at address 1324.
3. If no operand is specified, control is transferred to the first address of the program loaded.

\subsection*{17.3. GENERATE LITERALS (LTORG)}

The generate literal pool (LTORG) directive generates all literals previously defined into a data pool within the source program. The format of the LTORG directive is:


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 (19.3) 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 a 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 control 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 should be used within each control section.

\section*{ORG}

\subsection*{17.4. SPECIFY LOCATION COUNTER (ORG)}

The specify location counter (ORG) directive sets or resets the location counter to a specified value. The format of the ORG directive is:
\begin{tabular}{c|l|l} 
LABEL & \(\triangle\) OPERATION \(\Delta\) & OPERAND \\
\hline [symbol] & ORG & {\([\mathrm{e}]\)}
\end{tabular}
where:
e
Is a relocatable expression.
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.

Example:
\begin{tabular}{lll} 
LABEL & \(\triangle\) OPERATION \(\triangle\) \\
1 & 10 & 16
\end{tabular}

OPERAND

AREA ORG \(\quad++A+B\)

This statement reserves A plus B bytes of storage, where A and B are previously defined symbols with absolute values. If \(A=80, B=160\), and the value of the location counter is 1048, then 240 bytes are reserved beginning at the location 1048.

Additional examples of the ORG directive are included on the following page.

Examples:

1. An input area for an 80-byte card is defined with no subfields.
2. The input field is redefined in place to show two subfields.
3.
and
4. Redefine INPUT for different organizations of the field.

Instructions 1 through 4 define four different types of cards or other 80-byte records.

\section*{START}

\subsection*{17.5. PROGRAM START (START)}

The program start (START) directive defines the program name, the name of the first control section, and the initial location counter value. The format of the START directive is:
\begin{tabular}{c|l|l} 
LABEL & \(\triangle\) OPERATION \(\Delta\) & \\
\hline [symbol] & START & OPERAND \\
\hline
\end{tabular}
where:
a
Is an absolute expression.
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 can contain 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.

Examples:
\begin{tabular}{|c|c|c|c|}
\hline LABEL & \multicolumn{2}{|l|}{\(\triangle\) OPERATION \(\triangle\)} & OPERAND \\
\hline 1 & 10 & 16 & \\
\hline TEST & START & 1063 & \\
\hline TEST & START & X'427 \({ }^{1}\) & \\
\hline
\end{tabular}

The location counter contents for either of these statements would be 1064, which is the next higher multiple of 8 from 1063.

\section*{18. Base Register Assignment Directives}

The OS \(/ 3\) assembler converts storage addresses to base register and displacement values for insertion into instructions being assembled. To do this, the assembler must be informed of the available registers and the values assumed to be in those registers. The assembler directives USING and DROP are available for this purpose.
- The unassign base register (DROP) directive informs the assembler that certain registers are no longer to be used for base registers.
- The assign base register (USING) directive informs the assembler that the specified registers are available for use as base registers.

\section*{DROP}

\subsection*{18.1. UNASSIGN BASE REGISTER (DROP)}

The unassign base register (DROP) directive informs the assembler that the registers specified are no longer available for base register assignment. The format of the DROP directive is:
\begin{tabular}{l|l|l} 
LABEL & DOPERATION \(\triangle\) & \\
\hline unused & DROP & \(r_{1}\left[, \ldots, r_{n}\right]\)
\end{tabular}
where:
\(\mathbf{r}_{1}\left[, \ldots, \mathbf{r}_{\mathrm{n}}\right]\)
Specifies that the declared registers (0 through 15) are no longer available for base register assignment.

Registers previously made available for base register assignment may be dropped and made available again in a USING directive. (See 18.2.) The value assumed to be in a base register may be changed by coding another USING directive without an intervening drop of that register.

Examples:

1. This directive specifies that register 1 is no longer available to the assembler for base register assignment.
2. This directive specifies that registers 1,3 , and 4 are no longer available for base registers.

\subsection*{18.2. ASSIGN BASE REGISTER (USING)}

The assign base register (USING) directive 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. The format of the USING directive is:
\begin{tabular}{c|l|l} 
LABEL & \(\triangle\) OPERATION \(\triangle\) & \\
\hline unused & USING & \(v, r_{1}\left[, \ldots, r_{n}\right]\)
\end{tabular}
where:
v
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.
```

r

```

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.

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 displacements as if the operands 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}, \ldots, 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.

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.

\section*{Examples:}
\begin{tabular}{llll} 
LABEL & \(\triangle O P E R A T I O N \triangle\) & OPERAND \\
1 & 10 & 16 &
\end{tabular}
\begin{tabular}{lll} 
1. & \\
2. & USING & \(4 \varnothing \varnothing \varnothing, 8\) \\
3. & USING & \(8 \emptyset \varnothing \varnothing, 1,2,3,6,7,8,12\) \\
4. & USING & \(\div, 5\) \\
USING & TAG,R9
\end{tabular}
1. A range of 4096 bytes is covered by register 8 at location 4000 through 8095 . The value 4000 is assumed to be stored in register 8 .
2. The value 8000 is assumed to be in register 1,12096 in register 2,16192 in register 3, 20288 in register 6, 24384 in register 7, 28480 in register 8, and 32576 in register 12. These register numbers and their assumed values are entered into the USING table in the order specified.
3. Register 5 is used as the base register, with the value of the location counter contained in register 5.
4. The register declared by the symbol R9 is assumed to contain the base address of the symbol "TAG".

\section*{19. Program Linking and Sectioning Directives}

A program or a portion of a program assembled as a single unit is called a module. A complex program may consist of many modules; some may be standard subroutines that can be used in any program.

The assembler provides, as part of its output, information that allows modules to be linked together, loaded and then executed as a single program. Proper partitioning or sectioning reduces the execution time required to make changes to an existing program. If a change is required, only the module that is changed must be reassembled. The output is then linked with the remaining parts to produce the altered program. Proper partitioning of a program also reduces the number of symbols required in each of the separate assemblies.

A symbol defined in the label field of module \(A\) and addressed in module \(B\) must-be externally defined by an ENTRY directive in module A and defined by an EXTRN directive in module B. By using the ENTRY and EXTRN directives, proper linkage is supplied when the separate modules are assembled. This information is passed to the linkage editor by the external definition records and the external reference records, which are outputs of the assembler.

The assembler also provides an optional capability of dividing one module into different sections. A control section is a group of instructions, constants, and storage areas, the positions of which, relative to each other, are fixed and must remain fixed to ensure proper coding. Proper execution of instructions and data in one control section must not depend on their positions relative to instructions or data in any other control section. Because the assembler maintains a separate location counter for each section, control sections may appear in any order for input to the assembler. Statements belonging to one control section may be intermixed with statements belonging to one or more other sections. If the first statement of a control section is a START directive, its label names the control section.

Each module may have a maximum of 255 external symbol identification (ESID) items. An ESID item contains special information used by the linkage editor in relocating modules and module sections and in resolving references between modules. The following items cause the assembler to generate an ESID item:
- Each unique symbol used in a V-type address constant
- Each symbol used in a V-type address constant
- Each control section
- Each dummy control section
- Each common storage definition section

\section*{COM}

\subsection*{19.1. COMMON STORAGE DEFINITION (COM)}

The common storage definition (COM) directive enables the programmer to define a control section which is 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, or by loading a control section of the same name. Such CSECTS are called block data sections. 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 blank (unnamed) common section. Several like-named 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 like common storage are linked, the resulting module contains only one section corresponding to the like common sections in the input modules. The length of this section is the length of the largest like common section in the input modules. The format of the COM directive is:


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. (See 18.2.)

Examples:
```

    MODULE I:
    LABEL \triangleOPERATION\triangle I6 OPERAND
    ```
1. \(\begin{array}{lll}\text { MODI } & \text { CSECT } & \\ & \vdots \\ \text { ACOM } & \text { COM } & \\ \text { REBEW } & \text { DS } & \text { CLI25 } \\ \text { CHAYA } & \text { DS } & \text { CL8ø } \\ & \text { END } & \end{array}\)

MODULE 2:
LABEL \(\triangle O P E R A T I O N \triangle\) OPERAND
1016
3. \begin{tabular}{lll} 
MOD2 & CSECT & \\
& \begin{tabular}{l}
\(\bullet\) \\
ACOM
\end{tabular} & \begin{tabular}{l} 
COM \\
ELI \\
DS \\
END
\end{tabular}
\end{tabular}
1. When module 1 is assembled, it uses the common storage area defined by line 2.
2. The common storage area used by module 1 and module 2
3. When module 2 is assembled, it also uses the common storage area defined by line 2
4. The common storage area used by module 1 and module 2

The common storage area for these examples is 260 bytes long (see following listing). The fields REBEW and CHAYA are the same storage area as the first 205 bytes of the field ELI.
\begin{tabular}{|c|c|c|c|c|c|c|c|c|}
\hline \begin{tabular}{l}
Byte \\
Number
\end{tabular} & Hexadecimal Address & \multicolumn{3}{|c|}{Module 1} & Hexadecimal Address & \multicolumn{3}{|c|}{Module 2} \\
\hline 0 & 00000 & ACOM REBEW & \[
\begin{aligned}
& \text { COM } \\
& \text { DS }
\end{aligned}
\] & CL125 & 00000 & \[
\begin{aligned}
& \text { ACOM } \\
& \text { ELI }
\end{aligned}
\] & \[
\begin{aligned}
& \text { COM } \\
& \text { DS }
\end{aligned}
\] & CL260 \\
\hline 125 & 0007D & CHAYA & DS & CL80 & & & & \\
\hline 205 & & & END & & & & & \\
\hline 260 & & & & & 00104 & & END & \\
\hline
\end{tabular}

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.
- 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).

\subsection*{19.2. CONTROL SECTION IDENTIFICATION (CSECT)}

The control section identification (CSECT) directive indicates to the assembler the initiation or continuation of a control section. The format of the CSECT directive is:
\begin{tabular}{c|l|l} 
LABEL & \(\triangle\) OPERATION \(\Delta\) & OPERAND \\
\hline [symbol] & CSECT & unused
\end{tabular}

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.

Examples:

```

LABEL $\triangle$ OPERATIONA

```
```

    1 10 16
    ```
```

    1 10 16
    ``` OPERAND

1. The first control section of coding is labeled GROSS.
2. The second control section of coding is labeled DEDUCT.
3. The coding beginning at line 3 is a continuation of the section labeled GROSS.
4. The first control section of coding is labeled GROSS2X.
5. The second control section of coding is labeled DEDUCTX.
6. The coding beginning at line 3 is a continuation of the section labeled GROSS2X.

\subsection*{19.3. DUMMY CONTROL SECTION IDENTIFICATION (DSECT)}

A program may contain references to areas that have been defined in other modules. Addressing such areas is facilitated by describing the area and its format to the assembler as a dummy control section. Any statement following a dummy control section identification (DSECT) directive is identified as belonging to the dummy control section. The format of the DSECT directive is:


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.

Coding examples utilizing the DSECT directive are included on the following page.

Examples:

1. The coding following DSECT is assigned to a dummy control section.
2. CSECT begins a new control section or continues the current control section.

\subsection*{19.4. EXTERNALLY REFERENCED SYMBOL DECLARATION (ENTRY)}

Each module must declare to the assembler the symbols defined within the module to which reference is made by other modules. Each symbol is referred to as being externally referenced and is declared by the ENTRY directive. The format of the ENTRY directive is:
\begin{tabular}{c|c|c} 
LABEL & \(\triangle\) OPERATION \(\Delta\) & OPERAND \\
\hline unused & ENTRY & symbol[,symbol,...,symbol]
\end{tabular}

Each symbol in the operand field is declared to be defined in this module. Their name and assigned values are included in the output of the assembler as external reference records. (See 19.5.)

Example:
LABEL \(\triangle\) OPERATION \(\triangle\)
OPERAND
\(\begin{array}{lll}10 & 10\end{array}\)

ENTRY WRD32,REBEW,ILE,CHAYA

WRD32, REBEW, ILE, and CHAYA are symbols defined in module 1 for the use of other modules. ENTRY permits other modules to reference the symbol defined by the ENTRY directive declaring it.

\section*{EXTRN}

\section*{- 19.5. EXTERNALLY DEFINED SYMBOL DECLARATION (EXTRN)}

The assembler must be informed of all symbols used in the module being assembled that are defined in some other module. References to these symbols are called external - definitions; these symbols are declared in the externally defined symbol declaration (EXTRN) directive. The format of the EXTRN directive is:
\begin{tabular}{c|l|c} 
LABEL & \(\triangle\) OPERATION \(\Delta\) & OPERAND \\
\hline unused & EXTRN & symbol \([\), symbol,...,symbol \(]\)
\end{tabular}

Each symbol in the operand field is declared to be a symbol defined in some other module. (See 19.4.) 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.

Examples:
MODULE A:
\begin{tabular}{|c|c|c|c|}
\hline Label & \multicolumn{2}{|l|}{\(\triangle O P E R A T I O N \triangle\)} & OPERAND \\
\hline 1 & 10 & 16 & \\
\hline \multirow[t]{3}{*}{FOX} & mvo & DEST (5) , ORIG(3) & \\
\hline & DC & A (CAT) & \\
\hline & DC & A (DOG) & \\
\hline \multirow[t]{3}{*}{JOE} & BC & 8,1048 & \\
\hline & - & & \\
\hline & - & & \\
\hline \multirow[t]{6}{*}{MAT} & BCT & & \\
\hline & DC & \[
A(P \mid G)
\] & \\
\hline & - & & \\
\hline & - & & \\
\hline & Entry & FOX, JOE, MAT & \\
\hline & EXTRN & CAT, DOG, PIG & \\
\hline
\end{tabular}


In module A, the symbols FOX, JOE, and MAT are specified with the ENTRY directive so that they may be used in module \(B\) as specified by EXTRN.

In module B, the symbols CAT, DOG, and PIG are specified with the ENTRY directive so that they may be used in module A as specified by EXTRN.

\subsection*{19.6. SUBROUTINE LINKAGE}

In addition to writing the code in your external subroutines, you must provide for certain conventions that link your subroutines to your program. The conventions are:
- Saving and restoring the contents of the registers
- Establishing a new base register
- Branching back to the program

Each of these conventions uses a specific register. The table that follows lists the registers and their use.

\section*{Register Use}

1 Contains the address of the table holding variables being passed to the subroutine.

13 Contains the address of an 18-word area that will save the contents of the registers as they were before your subroutine began execution.

14 Contains the address that your program branches to after it finishes its execution.

15 Used as the base register
The format that follows shows how you should use these registers to meet these conventions.

1. This line uses the CSECT directive to name the subroutine.
2. This line saves the contents of the registers in an 18-word save area located at the address stored in register 13.
3. These two lines establish register 15 as the base register for the execution of the and subroutine.
4.
5. This line restores the contents of the registers from an 18 -word save area located at the address stored in register 13.
6. This line returns control to your program by branching to the address stored in register 14.
7. This statement must be the last line in the subroutine.

\section*{20. Listing Control Directives}

One of the outputs of the assembler process is a listing of source and object codes. The assembler directives that control the format of the listing have the following functions:
- Provide headings for each page
- Eject or skip to a new page
- Space for extra blank lines
- Provide for printing or nonprinting of the output

Table 20-1 is a summary of the assembler listing control directives available to the user OS/3 assembler.

Table 20-1. Listing Control Directives
\begin{tabular}{|c|l|c|}
\hline Directives & Basic Function & \begin{tabular}{c} 
Where \\
Discussed
\end{tabular} \\
\hline EJECT & Advance listing & 20.1 \\
\hline PRINT & Listing content control & 20.2 \\
\hline SPACE & Leave blank lines on listing & 20.3 \\
\hline TITLE & Listing title declaration & 20.4 \\
\hline
\end{tabular}

\section*{EJECT}

\subsection*{20.1. ADVANCE LISTING (EJECT)}

The advance listing (EJECT) directive causes the assembler to continue the assembly listing (Part 6, Section 28) on the top of the next printout page. The format of the EJECT directive is:
\begin{tabular}{c|l|l} 
LABEL & \(\triangle\) OPERATION \(\Delta\) & \\
\hline unused & EJECT & unused
\end{tabular}

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.

\subsection*{20.2. LISTING CONTENT CONTROL (PRINT)}

The listing content control (PRINT) directive enables the programmer to control the contents of the assembly listing. The format of the PRINT directive is:
\(\left.\begin{array}{c|l|l}\text { LABEL } & \text { DOPERATION } \triangle & \text { OPERAND } \\ \hline \text { unused } & \text { PRINT } & {\left[\begin{array}{l}\text { ON } \\ \text { OFF }\end{array}\right\}}\end{array}\right]\left[\left\{\begin{array}{l}\text { GEN } \\ \text { NOGEN }\}\end{array}\right\}\right]\left[,\left\{\begin{array}{l}\text { DATA } \\ \text { NODATA }\end{array}\right\}\left[\left[\left\{\begin{array}{l}\text { SINGLE } \\ \text { DOUBLE }\end{array}\right\}\right]\right.\right.\)
where:
ON
Specifies the listing is to be printed.
OFF
Specifies that no listing is printed.

\section*{GEN}

Specifies that lines generated by a macro instruction are printed.

\section*{NOGEN}

Specifies that lines generated by a macro instruction are not printed, except that the macro instruction and any MNOTE or PNOTE messages generated are printed.

\section*{DATA}

Specifies that all characters of each constant representation are printed.

\section*{NODATA}

Specifies that only the first eight characters of each constant representation are printed.

SINGLE
Specifies that the source listing is single-spaced.

\section*{DOUBLE}

Specifies that the source listing is double-spaced.

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 is to be turned ON. The options provided by the PRINT directive are keyword and 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.

Examples:
\begin{tabular}{|c|c|c|c|}
\hline LABEL & \multicolumn{2}{|l|}{\(\triangle\) PPERATION \(\triangle\)} & OPERAND \\
\hline 1 & 10 & 16 & \\
\hline 1. & PRINT & DATA & \\
\hline 2. & PRINT & OFF & \\
\hline 3.1 & PRINT & ON, GEN, DATA & \\
\hline
\end{tabular}
1. Data is printed in full.
2. Assembly listing is suppressed.
3. Assembly list printing is restored with complete printing of data constants.

\subsection*{20.3. LEAVE BLANK LINES ON LISTING (SPACE)}

The leave blank lines on listing (SPACE) directive causes the assembler to advance 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.
\begin{tabular}{c|l|l} 
LABEL & \(\triangle\) OPERATION \(\triangle\) & \\
\hline unused & SPACE & {\([i]\)}
\end{tabular}
where:
i
Is an unsigned decimal integer.
Examples:
\begin{tabular}{lll} 
LABEL & \(\triangle O P E R A T I O N \Delta\) & OPERAND \\
1 & 10 & 16
\end{tabular}
\begin{tabular}{lll}
1. \\
2. & SPACE & 6 \\
SPACE & 22
\end{tabular}
1. The assembler advances the print form six lines before printing the next line.
2. The assembler advances the print form 22 lines before printing the next line.

\section*{TITLE}

\subsection*{20.4. LISTING TITLE DECLARATION (TITLE)}

The listing title declaration (TITLE) directive provides data for the heading of each page of the assembler listing and advances the printer form to a new page. The format of the TITLE directive is:

where:
c
Is a heading of up to 100 characters enclosed in apostrophes.
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.

Examples:

1. The \(Z\) in column 72 specifies that the title is continued on the next line. At assembly time, the assembler replaces the system variable symbols \&SYSDATE and \&SYSTIME with the current date and time, respectively. (See Appendix G.)
2. The assembler puts the system date in \&SYSDATE at assembly time.

\section*{21. Input and Output Control Directives}

The OS/3 assembler input and output control directives provide the necessary control for sequence checking, formatting, and reproducing data. The directives in this section help you in writing the source code program and controlling the source code punched cards. The six directives are:
- ICTL

Controls the format of the program instructions.
- ISEO

Controls the sequence of the punched cards in the source deck.
- REPRO

Controls the production of linkage editor control statements in the object module.
- PUNCH

Produces a specified record at assembly time.
- COPY

Controls the inclusion of prefiled source statements into your source programs.
- CCW

Initiates input and output operations.

\section*{ICTL}

\subsection*{21.1. INPUT FORMAT CONTROL (ICTL)}

The input format control (ICTL) directive 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 colum 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. The format of the ICTL directive is:
\begin{tabular}{c|c|c} 
LABEL & \(\triangle\) OPERATION \(\triangle\) & \\
\hline unused & ICTL & {\([b][, e][, c]\)}
\end{tabular}
where:
b
Is an unsigned decimal integer specifying the beginning column. It must be between 1 and 75 .
e
Is an unsigned decimal integer specifying the ending column. It must be greater than or equal to \(\mathrm{b}+5\) and less than or equal to 80 .
c
Is an unsigned decimal integer specifying the continuation column. It must be greater than 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 \(\mathbf{c}\) is omitted or if e equals 80, continuation records are not allowed. If \(e\) is specified and \(e\) is less than 80 , a continuation statement is signalled by putting a nonblank character in column e+1 of the line to be continued.

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 card following START card), the ICTL terminates the assembly.

\section*{Examples:}
\begin{tabular}{ccc} 
LABEL & \(\triangle O P E R A T I O N \Delta\) & OPERAND \\
1 & 10 & 16
\end{tabular}
\begin{tabular}{l|l}
1. & \begin{tabular}{l} 
ICTL \\
\(2,79,1 \emptyset\) \\
ICTL
\end{tabular} \\
2,16
\end{tabular}
1. Coding is to follow a new format by starting in column 2, ending in column 79, and continuing on the following line in column 10.
2. Coding is to follow standard format except that it is to start in column 2.

\section*{ISEQ}

\subsection*{21.2. INPUT SEQUENCE CONTROL (ISEQ)}

The input sequence control (ISEO) directive 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. The format of the ISEQ directive is:

where:
I
Is a decimal integer specifying the left-most column of the field to be used for the sequence check.
r
Is a decimal integer specifying the right-most column of the field to be used for the sequence check; \(r\) must be greater than or equal to \(I\).

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 ISEO 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 ISEO directive is supplied, no sequence checking occurs.

\section*{Example:}


Input record sequence is to be checked using the sequence numbers found in columns 75 through 79.

\subsection*{21.3. REPRODUCE FOLLOWING RECORD (REPRO)}

The reproduce following record (REPRO) directive is used to reproduce a record in its entirety (columns 1 through 80) during assembly time. This directive is used to produce statements to precede or succeed the object module and eliminates the necessity of manually inserting them. The format of the REPRO directive is:


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.

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.
Example:
\begin{tabular}{lll} 
LABEL & \(\triangle O P E R A T I O N \Delta\) & OPERAND \\
1 & 10 & 16
\end{tabular}

\section*{PUNCH}

\subsection*{21.4. PRODUCE A RECORD (PUNCH)}

The produce a record (PUNCH) directive 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. The format of the PUNCH directive is:
\begin{tabular}{c|l|l} 
LABEL & \(\triangle\) OPERATION \(\triangle\) & \\
\hline unused & PUNCH & \({ }^{\prime} \mathbf{c}_{1}, \ldots, \mathbf{c}_{\mathbf{8 0}}{ }^{\prime}\)
\end{tabular}
where:
\(\mathbf{c}_{1}, \ldots, \mathrm{C}_{80}\)
Represents a string of up to 80 characters produced as a record in the object code output.

The following conditions apply to the characters specified 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 characters for the limit of 80 , a pair of apostrophes or ampersands written to express a single apostrophe or ampersand counts as one character.

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.

Although this directive may be included anywhere in the program, it cannot be used before a macro definition.

Variable symbol substitution is performed within the operand field.
Example:
```

labEL \OPERATION\triangle 10 OPERAND

```
PUNCH 'INCLUDE XYZ,USERLIB'

The record \(X Y Z\) is included from USERLIB at assembly time.

\subsection*{21.5. INCLUDE CODE FROM A LIBRARY (COPY)}

The include code from a library (COPY) directive causes the source module identified in the operand field of the COPY directive to be included directly into the source program being assembled. The format of the COPY directive is:
\begin{tabular}{c|l|l|} 
LABEL & \(\triangle\) OPERATION \(\triangle\) & \\
\hline unused & COPY & Symber
\end{tabular}
where:
symbol
Identifies the source module to be copied by the assembler. Only one symbol may be used.

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. The last statement in the source module may not be continued into the source program being assembled. Statements included in the program by a COPY directive are assumed to be in standard format regardless of any ICTL directives in the program.

Example:
\begin{tabular}{llll} 
LABEL & \(\triangle\) OPERATIONA & OPERAND \\
1 & 10 & 16 &
\end{tabular}
COPY SUBRUT

SUBRUT is copied from a source library and placed into the calling program.

\section*{CCW}

\subsection*{21.6. CHANNEL COMMAND WORD (CCW)}

The channel command word (CCW) defines an 8-byte field aligned on a double word boundary and is located in main storage. The CCW is used to initiate I/O operations such as reading and writing. It has four operands which specify the contents of the channel command word. Each operand is separated by a comma and all four operands must appear in the operand field.

Format:
\begin{tabular}{c|c|c} 
LABEL & \(\triangle\) OPERATION \(\triangle\) & OPERAND \\
\hline [symbol] & CCW & op \(_{1}, \mathrm{op}_{2}, \mathrm{OP}_{3}, \mathrm{op}_{4}\)
\end{tabular}
where:
\(\mathrm{op}_{1}\)
Is an absolute expression that specifies the command code. The command code defines the I/O operation to be performed. This value is right-justified in byte 1.
\(\mathbf{o p}_{2}\)
Is an expression that specifies the address of the first byte of data in main storage to be controlled. This value is located in bits 13 through 31. Bits 8 through 12 are set to zero.
\(\mathrm{op}_{3}\)
Is an absolute expression that specifies the flags for bits 33 and 34, and zeros for bits 32 and 35 through 47 . Flag bits are set if a specific option is being used.
\(\mathrm{op}_{4}\)
Is an absolute expression representing the byte count which specifies the number of bytes to be controlled. This value is right justified in bytes 7 and 8.

Operational Considerations:
- If a symbol is used in the label field, it references the address of the leftmost byte of the CCW. Its length attribute is eight.
- All four operands must be specified.
- For more detailed information on the use of the CCW, see the processor programmer reference manual, UP-8052 (current version).

\section*{Example:}
\begin{tabular}{llll} 
LABEL & \(\triangle\) OPERATION \\
1 & 10 & 16 & OPERAND
\end{tabular}
\begin{tabular}{|c|c|c|}
\hline & CCW & 2,INAREA, \({ }^{\prime} 8 \square^{\prime}\), \(8 \emptyset\) \\
\hline CCWI & CCW & X'ø3', LOC+24, X'9め',55 \\
\hline & CCW & 5,8, \(\mathbf{\prime}^{\prime}\) øめ', 128 \\
\hline
\end{tabular}


\section*{PART 5. BAL MACROS}


\section*{22. Macro Facility}

\subsection*{22.1. THE MACRO PROCESSOR}

The OS/3 macro facility processes macro call instructions. This macro processor functions somewhat like a compiler and provides BAL users with a higher level basic assembler language. The OS \(/ 3\) macro call instructions that make up this language are stored in the macro library file ( \(\$ \mathrm{Y} \$ \mathrm{MAC}\) ). Each macro call instruction provided by Sperry Univac (data management, sort/merge, etc.) generates an open subroutine each time it is used in a program. An open subroutine is a set of BAL source instructions, designed to perform a particular function, that must be inserted into a program at each place desired. (The set of BAL instructions that make up an open subroutine is also called inline expansion code). The macro facility expands the OS/3 macro definitions from \$Y\$MAC and inserts them into a program in place of a macro call instruction.

Although the macro processor is far from being a high-level language compiler like COBOL or FORTRAN, it has language statements that must be interpreted and reduced to machine instructions just like any compiler. We no longer have an assembler that just converts one source instruction to one machine instruction. We now have an assembler that accepts one source statement in the form of a macro call instruction and converts this one statement into as many BAL source instructions as required to perform the particular function.

The macro processor is a valuable tool for the BAL programmer. Any programmer who writes his programs in assembly language quickly discovers the existence of macro instructions (colloquially known as macros). Most programmers use data management macros to define their files (DTFs) and to process them (OPEN, GET, PUT, etc). These macros were created for a specific reason. For example, to open a file might take 15 instructions in a particular sequence. If you want to open five files, you have to code this 15 -instruction sequence five times. The only differences in these instructions that you would have to code would be the instruction parameters that generally vary from file to file. To avoid this boring and repetitive process, which also provides opportunity for making coding errors, data management macro instructions are provided for your use to define and process the necessary instruction sequences. These sequences are known to be error free, and you can generate your specific instruction sequences merely by filling in parameters in two or three lines of coding.

If you are an experienced BAL programmer, you should be familiar with macroprogramming because, to write any type of worthwhile BAL program, you have to use data management macro instructions. This means you've studied the data management instructions, and possibly others, and used them when writing BAL programs. You know what inline expansion code looks like because you are a user of macro calls and have seen inline code in your source listings.

For instance, look at the listing shown in Figure 22-1. This program has five macro call instructions, and the inline code that immediately follows each call instruction is marked with a plus sign. The inline code shown in this listing is generated via macro call instructions designed by Sperry Univac. Each call is designed to produce a sequence of source instructions that will perform a specific function. The DTFPR macro instruction, shown in Figure 22-1, is designed to generate all the DC statements required to define a printer file for data management. If a DTFPR didn't exist, you would have to code all the DC statements needed to create a printer file. The purpose of this part of the user guide is to teach you how to become more proficient at using macro call instructions. We are going to teach you how to design your own macros, not how to call macros. You can learn about the macro instructions Sperry Univac provides by reading the related user guides. If you are experienced in macro design, you would be better off referring to the assembler programmer reference, UP-8227 (current version), and not this user guide because the discussion in this part is meant for novice macro designers.


Figure 22-1. Example of Inline Macro Expansion (Part 1 of 2)


Figure 22-1. Example of Inline Macro Expansion (Part 2 of 2)

\subsection*{22.2. MACRO SOURCE CODE}

Although you've probably seen a lot of inline expansion code, chances are you have probably never seen macro source code. Inline expansion code originates from macro source code. Whenever you use an OS/3 macro call instruction, the macro facility retrieves the macro source code from \(\$ Y \$ M A C\), which contains a macro definition for each macro call instruction provided by Sperry Univac. Each macro definition holds the BAL source instructions that are to be generated inline. If you have a BAL program that has become popular and is recurring in other programs and you want to make this code available via a macro call instruction, you have to design a macro definition. You use the statements provided with the assembler macro faciity to transform your BAL program into a macro definition. It is the responsibility of the macro facility, which is part of the assembler, to process your macro definition. The macro facility works entirely with macro source code while a conventional assembly recognizes and processes program source code. Macro source code consists of macro facility source statements and BAL source statements.

There are three types of source code that are always associated with the macro facility:
1. Macro source code
2. Macro call instruction
3. Inline expansion code

The order in which these different types of source code are listed is the order of their evolution. First, you must have a macro definition (macro source code) before you can use a macro call instruction to generate inline expansion code. An important fact to keep in mind is that all of this code is source code. The macro facility works entirely at the source code level, from the macro call instruction, to the \$Y\$MAC, to the inline expansion code. The following diagram shows the interactions of each type of code when a macro call instruction is used.


The macro facility performs preassemble processing. It has nothing to do with turning source code into object code. The basic function of the macro facility is to search for the proper macro definition when a macro call instruction is used in a program, and generate the requested inline expansion code. This is done before the assembler starts creating an object module. When the assembler detects a pseudo-operation code (a mnemonic code that is not a machine instruction), that code is turned over to the macro facility. Each macro definition has a unique call-name that is identified in the operation field of the macro call instruction. The macro facility searches for the macro definition that matches the call-name and generates the requested inline expansion code. The macro facility expands the code inline before the assembler starts converting the program source code to object code.

The macro facility has capabilities other than just inserting the BAL source instructions that are contained inside a macro definition inline in place of the macro call instruction. There are other elements of the expansion that you can control. You can use the macro facility to perform variable parameter replacement and variable inline expansion code. If you've used macro call instructions supplied by Sperry Univac, then you are familiar with positional and keyword parameters. The values you code as positional or keyword parameters in the call instruction replace variable symbols coded in the macro definition. Using variable parameter replacement, you can use the values given in the call instruction to replace variable symbols coded in the label, operation, or operand field of any BAL instruction in the macro definition.

Variable inline expansion code is another level of control that allows you to design a macro definition that will vary the pattern of BAL instructions generated from within the macro definition. Conditional assembly language statements are used to design the logic for variable inline expansion code. Variable parameter replacement and variable inline expansion code allow you to give the user of your macro call instruction more control over the code that is generated. If you use these coding techniques when designing macro definitions, the user can control calculations performed by the open subroutine and select the functions that are to be performed.

\section*{23. Macro Design}

\subsection*{23.1. THE MACRO DEFINITION}

You can define your own macro call instructions by using the statements provided with the assembler macro facility. When you define a call, it must be in a formalized pattern called a macro definition. Each macro definition is organized into the following parts:


The two major areas to consider when designing a macro definition are the heading and the body; the trailer is merely a single statement indicating the end of the macro definition. The heading is always the first part of the macro, and it consists of statements you use to design the macro call instruction. The body, which immediately follows the heading, is where you design the inline expansion code. Model statements are used in the body to construct a model of the inline expansion code you want generated by the macro call instruction. If you design a basic macro definition, the model statements are merely a copy of the BAL source instructions that are to be expanded inline. A basic macro definition is one that does not require any parameters from the macro call instruction and will generate the same sequence of source instructions, with no modifications, each time it is called. The following diagram shows the operation of a basic macro definition.


The only real design consideration for the basic macro definition is the call-name, which is the mnemonic that appears in the operation field of the macro call instruction. You must give the call-name in the heading.

If you want variable parameter replacement in the body, you must give further consideration to coding the heading and body. Variable parameter substitution is substituting parameter values coded in the macro call instruction in place of arguments given in the label, operation, or operand fields of model statements. The following diagram shows the operation of a macro definition designed to perform parameter substitution.


You must design the body to indicate where the arguments are and design the heading to indicate how the parameter values are to be coded in the macro call instruction and how the body is to reference the parameter values in the macro call instruction.

If you want variable inline expansion code, you must include model statements other than the BAL source statements that you want expanded inline. These other model statements are called conditional assembly language statements, and they enable you to vary the pattern of the inline expansion code produced by the macro definition. The pattern of code generated depends on a value given in the macro call instruction. The following diagram shows the operation of a macro definition designed to perform variable inline expansion code.


Parameter 2 in the call indicates which pattern of inline expansion code is to be generated. The second statement in the body is a conditional assembly that tests the value of parameter 2. If the value of parameter 2 is 1 , then a branch is made to STORE and the A instruction is not included in the inline expansion code. If the value of parameter 2 is 2 , no branch is made and all of the instructions are generated.

\subsection*{23.2. MACRO DEFINITION STORAGE}

After you've designed a macro definition there are several things you can do with it. If it is for your program and not to be used by anyone else, you can put it in your source program when it is assembled. A macro definition is placed in the source program immediately following the start-of-data ( \(/ \$\) ) job control statement and before the START assembler directive (Figure 23-1). The macro definition is stored in the temporary job run library file ( \(\$\) Y\$RUN), and it is only available during execution of the current job. To make a macro definition available to anyone at anytime, it must be stored in a library other than \$Y\$RUN (either \$Y\$MAC or your own library). Figure 23-2 shows how a macro definition is obtained from \(\$\) Y \(\$\) MAC. To add a macro definition from cards to a disk file, you can use the ELE librarian control statement. (For more information on the system library and creating library files, see the system service programs (SSP) user guide, UP-8062 (current version)). Whether a macro definition is stored in a library or is part of a source program depends on whether you want the macro to be temporary or permanent.


Figure 23-1. Accessing a Macro Definition Submitted in the Source Deck


Figure 23-2. Accessing a Macro Definition Stored in a Library

\subsection*{23.3. THE MACRO CALL INSTRUCTION}

The macro call instruction has two functions: to call a macro definition and to pass parameters to the macro definition, if required. The label and operand fields of the macro call instructions are used for passing parameters, and the operation field is used to call the macro definition:
\begin{tabular}{c|l|l} 
LABEL & \(\triangle\) OPERATION \(\triangle\) & \\
\hline [symbol] & call-name & {\(\left[p_{1}, p_{2}, \ldots, p_{252}\right]\)}
\end{tabular}

Just as the inline expansion code originates from the macro definition body, the macro call instruction originates from the heading. The contents of the label, operation, and operand fields of the macro call instruction are specified in the heading of the macro definition. You actually use the heading of the macro definition as a dummy call line to design the format of the macro call instruction. The following diagram shows an abstract representation of how the heading represents each field of the macro call instruction. (The fields shown in the diagram of the heading do not necessarily appear exactly where they are shown; the diagram is provided to illustrate the association the heading has with the call; the exact format of the heading is described in the following discussion.)


Everything you want the user to code in the macro call instruction must be represented in the heading. If you design a basic macro definition, the only thing that you require from the macro call instruction is the call-name in the operation field. The call-name that you want the user to use to call your basic macro definition is duplicated in the heading. All callnames:
1. Must begin with an alphabetic character or special letter.
2. Must not exceed eight characters in length.
3. Must not contain embedded blanks or other special characters.
4. Must not be the same name as any of the Sperry Univac mnemonic operation codes or any mnemonic operation codes you have in your library. This restriction is normally true unless you use the OPSYM directive to override a valid mnemonic code (16.2).

A macro definition that is designed to perform variable parameter replacement must indicate, in the heading, the type and number of parameters to expect from the macro call instruction. Values may be passed to the macro definition from the label field or the operand field of a macro call instruction. If you want to use the symbol in the label field of a call instruction, you must have a label-argument in the heading. Before the macro definition can pick up the values from the parameter-list in the macro call instruction, they must be coded according to the parameter-specifications given in the heading. You use the heading to specify how many parameters are to be coded in the macro call instruction and whether the parameters are keyword or positional, or both. The macro call instruction must be coded in accordance with the heading before the values in the parameter-list can properly replace the arguments in the body.

The heading can specify a parameter-list of up to 252 parameters. All parameters must be separated by commas and each parameter can be from 0 to 127 characters in length. In order to be properly picked up by the macro definition, the string of characters comprising a macro instruction operand must satisfy 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.

\section*{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.

The specifications for the parameter-list of a macro call instruction should be thoroughly documented for the user of the macro. He should know the range of values each parameter is to have and the type of parameters.

There are two ways the macro definition can recognize values in the parameter-list: by the position of the value in the list or by the name associated with the value in the list. A value identified by the position it holds in the list is called a positional parameter, and one that is identified by a name is called a keyword parameter. When the parameter specifications in the heading indicate that the parameter-list is to contain only positional parameters, the corresponding values in the operand field of the macro call instruction must appear in the same operands each time the call is used. If any positional parameters are omitted in the call, this omission must be indicated by retaining the comma in the parameter's place. For instance, if a macro has the capacity to accept four positional parameters, the call doesn't necessarily have to give all the parameters because some of the parameters may be optional to the macro's function. The proper coding of some of the possible combinations for four positional parameters is:
\begin{tabular}{|c|c|c|c|}
\hline LABEL & \multicolumn{2}{|l|}{\(\triangle\) OPERATION \(\triangle\)} & \multirow[t]{2}{*}{OPERAND} \\
\hline 1 & 10 & 16 & \\
\hline NAMEI & CALL & P1, P2, P3, P4 & \\
\hline NAME2 & CALL & , P2, P3, P4 & \\
\hline NAME 3 & CALL & P1, ,P3,P4 & \\
\hline NAME 4 & CALL & P1, P2, P4 & \\
\hline NAME5 & CALL & P1, P2, P3, & \\
\hline NAME6 & CALL & PI, , P4 & \\
\hline NAME 7 & CALL & PI & \\
\hline
\end{tabular}

It is not necessary to retain the commas for trailing positional parameters; if you are not going to code any of the remaining positional parameters in a call line, you do not have to code the commas for those parameters. But it doesn't matter if you do code the commas. I could have left out the last comma for CALL in NAME5 or I could have left the commas in for CALL in NAME7.

The following are typical examples of positional parameters with their calls:
\begin{tabular}{lll} 
& OPEN & INFILE \\
READIN & GET & INFILE, WORKI \\
WRITI & PUT & PRINTER,HEDR \\
ENDIN & CLOSE & INFILE, \\
ACTION & OPR & TEXT,, REPLY,AREA
\end{tabular}

Keyword parameters, unlike positional parameters, are not referenced by the position they hold in the call line but by the name of the keyword in the call line. A keyword parameter consists of three parts: a keyword, an equal sign, and a value:

> keyword=value

The keyword is an alphanumeric string from one to seven characters in length. Actually, a keyword may be longer than six, but the macro facility recognizes only the first seven characters as the true name and truncates the remaining characters. The value is dependent upon the arguments in the macro.

Keyword parameters, like positional parameters, must be separated by commas but aren't restricted to being in the same position each time they are coded. This nonpositional characteristic eliminates the inconvenience of comma counting because keyword parameters can be coded in any order and, when a keyword is omitted, a comma does not have to be retained in the parameter's place. Keyword parameters also provide another coding choice: default values for omitted parameters. The macro may be designed to automatically provide a preselected value for a keyword parameter that is omitted from a call line. To illustrate, suppose we had a keyword parameter called CHOICE. This parameter could be assigned optional values, such as ONE, NONE, or ALL. We could then write the parameter in the macro with a default value equal to ALL. Now when we call the macro, the ALL option is used unless the call specifically states another parameter such as CHOICE \(=\) ONE or CHOICE=NONE. This is true even if we omit the keyword parameter in the call. However, if a keyword is not given a default value within a macro and it is omitted in the call, it receives the value of a null character string.

Following are examples of typical macros with keyword parameters:
\begin{tabular}{|c|c|c|}
\hline label & \(\triangle\) OPERATION \(\triangle\) & OPERAND \\
\hline TAPOUT & DTFMT & TYPE=OUTPUT,FLBL=STD,RCFM=FIXBLK, BKSZ=2200,RCSZ=220,IOA1=TAPAREA, WORK=YES \\
\hline PRINTR & DTFPR & RCFM=FIXED,BKSZ=132,IOA \(1=\) LIST,WORK=YES PRAD=2,PRTOV=YES,ERROR=RECOVR \\
\hline
\end{tabular}

Both positional and keyword parameters may appear in the same call line. This is known as a mixed-mode macro call. In a mixed mode macro call, the positional parameter string must be coded before the keyword parameter string:
\begin{tabular}{c|l|l} 
LABEL & \(\triangle\) OPERATION \(\Delta\) & \\
\hline OPymbol] & call-name & \(p_{1}, \ldots, p_{n}, k_{1}, \ldots, k_{n}\)
\end{tabular}

Positional and keyword parameters may have a subordinate list of parameters called subparameters. This sublist of parameters permits the macro call line to provide more than one value in a single parameter position. A sublist for positional parameters is coded as follows:
\begin{tabular}{c|c|c} 
LABEL & \(\triangle\) OPERATION \(\triangle\) & OPERAND \\
\hline [symbol] & call-name & \(\left(p_{1,1}, p_{1,2}, \ldots, p_{1, n}\right), \ldots,\left(p_{n, 1}, \ldots, p_{n, n}\right)\)
\end{tabular}

A sublist for keyword parameters is coded as follows:
\begin{tabular}{c|c|c} 
LABEL & DOPERATION \(\triangle\) & OPERAND \\
\hline [symbol] & call-name & \(k_{1}=\left(p_{1}, \ldots, p_{n}\right), \ldots, k_{n}=\left(p_{1}, \ldots, p_{n}\right)\)
\end{tabular}

The parameter sublist must always be enclosed by parentheses, and the subparameters are coded as positional parameters (parameter omission is indicated by retaining commas).

When you design a macro definition that requires parameters from the macro call instruction, the heading is the means to pass values from the call to the body. There are two methods available for designing the call-to-heading-to-body communications cycle that generates inline expansion code. You can use a macro definition in PROC format or a macro definition in MACRO format. Each uses a different technique in the heading for designing the call instruction. If a SET symbol appears in the operand entry of a macro instruction, attribute information is not provided and the operand may not be accessed as a sublist.

\section*{24. Two Types of Macro Definitions}

\subsection*{24.1. PROCS AND MACROS}

The OS/3 macro facility can process two types of macro definitions. One type is called a procedure (PROC) and has been the standard type of macro definition for Sperry Univac systems for many years. The other type is called a macro (MACRO) and is available primarily to be compatible with the IBM 360/20 system. You can design a macro definition in PROC format or MACRO format; the OS \(/ 3\) macro facility will accept and process either one. Although the statements inside a PROC are a little different from those inside a MACRO, both types of definitions will always have a heading, a body, and a trailer and will always be in that order. Actually, the only differences between the two types of definitions occur in the heading and the trailer. The body which contains the model statements, is the same for both PROCs and MACROs. Let's take a look at a macro definition heading in MACRO format and compare it to the same macro definition heading in PROC format and discuss their differences without going into a lot of detail about the operation of each. Look at Figure 24-1 and you'll see the differences between the headings for the PROC and the MACRO.
\begin{tabular}{|c|c|c|c|}
\hline \multicolumn{4}{|c|}{PROC HEADING} \\
\hline & LABEL & \(\triangle\) OPERATION \(\triangle\) & OPERAND \\
\hline PROC STATEMENT & label-argument & PROC & parameter-specifications \\
\hline NAME STATEMENT & call-name & NAME & pos-O \\
\hline
\end{tabular}
\begin{tabular}{l|c|c|c|}
\multicolumn{4}{c|}{ MACRO HEADING } \\
\cline { 2 - 4 } MACRO STATEMENT & LABEL & \(\triangle\) OPERATION \(\triangle\) & OPERAND \\
\cline { 2 - 4 } & unused & MACRO & unused \\
\cline { 2 - 4 } & label-argument & call-name & parameter-specifications \\
\hline
\end{tabular}

CALL INSTRUCTION
\begin{tabular}{|c|c|c|}
\hline LABEL & \(\triangle\) OPERATION \(\triangle\) & OPERAND \\
\hline symbol & call-name & parameter-list \\
\hline
\end{tabular}

Figure 24-1. PROC and MACRO Heading

\subsection*{24.2. CALL INSTRUCTION DESIGN}

Even through the format for the PROC and MACRO headings is different, it doesn't affect the coding rules for the call instruction format. When a user issues a call instruction, he is completely unaware of whether the call communicates with a PROC or MACRO. This is because both headings have the same counterpart fields that represent each field of the call. The label-argument in each heading represents the symbol in the label field of the call instruction, the call-name in each heading is the call-name used in the call instruction, and the parameter-specifications in each heading define the specifications for the parameter-list in the call. The fields representing the call instruction are in different positions in the heading for the PROC and MACRO, but they serve the same function for each.

Variable symbols are used to create the label-argument and parameter-specifications in the PROC and MACRO heading. The variable symbol is a macro language symbol used as a dummy argument in a macro definition. It's a dummy argument because the variable symbol will be replaced with a value when the macro definition is called by the macro call instruction. Since a variable symbol is recognized and processed only by the macro facility, it is distinct from the symbols used in program source code. The macro facility requires that any symbol to be used as a variable symbol must have an ampersand ( \(\&\) ) as an identifier in the first character position. There are seven character positions after the ampersand that are used to construct the variable symbol. Because a variable symbol must always be identified with an ampersand in the first character position, a variable symbol will always be at least two characters in length (an ampersand and a character) and eight characters at the most (an ampersand and seven characters). The character position after the ampersand can contain a letter (A through Z) or a special letter (?\$\#@) and each of the remaining seven positions can contain a letter, special character (see 2.4 for character types), or a digit (0 through 9):


Some examples of legal variable symbols are:

\section*{\&ABCDEFG}
\&\#BCDE67
\& \({ }^{6}\)
\&@
Illegal variable symbols:
```

ABCDEFGHI
\&\&CDEFGHI
\&=KEY
\&95\&95
\&

```

When variable symbols are used, the following restrictions must be considered:
- 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.
- A variable symbol may not be used in the operation field of a statement.
- 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.

The OS/3 assembler provides system variable symbols. When a system variable symbol is used in a model statement, a value is automatically provided by the macro facility. The system variable symbols available with the macro facility are given in Appendix G.

Both the PROC and the MACRO use two statements in the heading; the PROC may have more than two but must have at least two. When designing a MACRO, you use the first statement strictly for indicating MACRO format; the entire second statement, called the prototype statement, is used to design the call instruction. In a PROC, the first statement is not only used to indicate a PROC format but is also used, along with the second statement, for call instruction design. The heading of the PROC consists of the PROC and NAME statement, and the heading of a macro consists of a MACRO and prototype statement.

In MACRO format, each field of the prototype statement is used for designing each corresponding field in the macro call instruction. If you want to reference the label field in the call instruction, you must indicate a variable symbol for the label-argument in the label field of the prototype statement. The call-name for the call instruction is indicated in the operation field of the prototype statement, and the parameter-specifications for the parameter-list to be coded in the call instruction are indicated by variable symbols in the operand field of the prototype statement. The variable symbols for indicating a labelargument and for specifying positional and keyword parameters are coded in the prototype statement as follows:


If you want the call instruction to pass values as positional parameters, variable symbols representing these positional parameters are coded starting in operand 1 of the prototype statement and are separated by commas. Each positional parameter is represented by a unique variable symbol that must be coded in the prototype statement in the same position its corresponding values are to be coded in the operand field of the call. If you want a mixedmode call instruction, you must code variable symbols representing the keyword parameters immediately following the variable symbols for positional parameters. The format of the keyword parameter variable symbol is:
\[
\& k e y=
\]
where key is a 1 - to 6 -character keyword to be used in the call. The keyword in the call may be longer than six characters, but the macro facility will only use the first six characters as the keyword name. If you want the call to pass values using only keyword parameters, then you code only keyword parameter variable symbols starting in operand 1 of the prototype statement. When designing a call instruction from a prototype statement, you can match each field fo the statement with each field of the call, and you can also match value in the parameter-list of the call with each variable symbol in the operand field of the prototype statement. The prototype statement is the dummy call instruction used for designing the macro call instruction.

Even though you can compare the prototype statement with the call instruction on a field-by-field basis, you cannot use a single statement in the PROC heading for a similar comparison. This is because you must use both the PROC and the NAME statement to design the call instruction. The label field of the PROC statement is used to indicate the variable symbol for referencing the symbol in the label field of the call instruction, and the operand field of the PROC statement is used to indicate the variable symbols used for referencing the parameter-list in the operand field of the call. The coding of parameterspecifications in the operand field of the PROC statement is different from the coding in the prototype statement:


You specify positional parameters by indicating a variable symbol in operand 1, and you indicate the number of positional parameters to appear in the call in operand 2. If you want a mixed mode call, the keyword parameters are indicated by coding keyword variable symbols starting in operand 3. You specify keyword-parameters only, by coding commas in operand 1 and 2 and then coding the keyword parameter variable symbols. The PROC statement is used to indicate the label-argument and the parameter-specifications, and the NAME statement is used for specifying the call-name.

In effect, what the NAME statement does is to make the call-name an independent entity in the PROC heading. Since the call-name is disassociated from the parameter-specifications, it becomes easy to introduce another method of parameter submission without having any effect on the variable symbols in the heading. This order parameter is positional parameter zero and is submitted in the operand field of the NAME statement. Each value you want positional parameter zero to have must be coded in the operand field (pos-O) of a separate NAME statement. And each NAME statement must have a different call-name in the label field. Thus, you can vary the value of positional parameter zero by varying the call-name used in the call instruction. At any point in time, positional parameter zero has the value of the pos-O coded in the operand field of the NAME statement that matches the call-name used in the call instruction. The PROC makes positional parameter zero possible through efficient use of two fields that are unused in the MACRO heading. These two fields are used in the PROC to disassociate the call-name from the parameter-specifications and split the call design responsibility between the two heading statements.

So, where the MACRO uses one statement in the heading to communicate directly with the call line, the PROC uses both statements, one statement for associating parameter replacement and another for naming the call-name. Using the one statement in the heading to interface the call-line instead of two, as the PROC does, seems like a straight-forward way of doing things. But when you read about how to use the PROC, you'll find the splitheading characteristic of the PROC heading works to your advantage. The PROC offers one more additional parameter reference (positional parameter zero) and intrinsically allows the body to reference the parameters in the call line by the number of the position and not by the symbolic name of the position.

A complete picture of the PROC and MACRO construction compared with the call instruction format is shown in Figure 24-2. It shows the format of the heading, body, and trailer for each type of macro definition. The rules for coding the model statements in the body are the same for the PROC and MACRO. These rules are:
- The label field may contain a symbol, a variable symbol, or a sequence symbol, depending on the operation defined. Comments 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, or ISEQ.
- 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 program source module is called an outer macro instruction. A macro instruction that appears in a macro corresponding to an outer macro instruction is called 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.

The trailer indicates the end of a macro definition. The mnemonic code END is used in the PROC and MEND is used in the MACRO. The label and operand fields are not used.
\begin{tabular}{|c|c|c|c|c|}
\hline \multirow[t]{2}{*}{} & \multicolumn{4}{|c|}{PROC CONSTRUCTION} \\
\hline & LABEL & \(\triangle\) OPERATIONA & \multicolumn{2}{|r|}{OPERAND} \\
\hline HEADING & [teymbol] collismers & \begin{tabular}{l}
PROC \\
NAME
\end{tabular} & \[
\begin{aligned}
& \text { [spos,en] } \\
& {[p o s-0]}
\end{aligned}
\] &  \\
\hline BODY & \(\left[\left\{\begin{array}{l}\text { symbol } \\ \text { sesymbol } \\ \text { symboi }\end{array}\right\}\right]\) & mnemonic-code mnemonic-code & \begin{tabular}{l}
operands \\
operands
\end{tabular} & \\
\hline trailer & unused & END & unused & \\
\hline
\end{tabular}


Figure 24-2. PROC, MACRO. and Call Instruction Comparison

\subsection*{24.3. PASSING PARAMETERS TO THE BODY}

The discussion of the heading thus far has been from the call instruction design point of view, but the heading also establishes a homologous relationship between the call instruction and the body. Body references to the values in the call instruction stem from the variable symbols used for designing the call instruction. The variable symbols used in the heading to represent the label and operand fields of the call instruction are used as arguments in the body to reference the values in the call instruction. Variable symbols in the body that directly reference values in the call instruction are called symbolic parameters. When you use a symbolic parameter in the body, you are directly referencing its associated value in the call instruction and, when you call the definition, the values in the call are substituted in place of the symbolic parameters. This call-to-body communications cycle is as follows:

MACRO CALL INSTRUCTION


The heading of the macro definition thus serves not only as the design medium for the macro call instruction but also dictates how the arguments in the body are to reference the values in the call instruction. Coordination of values and arguments is accomplished by using variable symbols in the label-argument and parameter-specifications fields of the heading. The variable symbols used in the heading to represent the symbol, and the values in the parameter-list, are the variable symbols used in the body to reference the label and operand fields of the macro call instruction. Communications between a macro call instruction and a macro definition that is capable of variable parameter replacement is shown in Figure 24-3.

The following sequence of events occurs when a macro call is issued: The macro facility finds the macro definition called upon, matches the parameters given in the call to the variable symbols in the heading, and (wherever the body references a variable symbol in the heading), plugs the matched value into the body. Then, the body, with the substituted parameters, is put in the source program where the macro call instruction appeared. A variable symbol in a macro definition body represents either the label in an issued macro call instruction or one of the operands in that macro instruction.


Call the macro.
(2) Substitute the parameters.
(3) Inline expansion
p Variable symbol
Figure 24-3. Communication between Macro Instruction and Macro Definition

When a variable symbol appears as a symbolic parameter in a model statement, it may be concatenated (joined) with other variable symbols or characters. Some combinations of variable symbols and characters require a period as a separator between the variable symbol and the joined character to distinguish where the variable symbol stops and the concatenation begins. Other combinations do not require a period as a connector because the concatenation is implied by certain characters that are recognized as character string terminators. When the period is properly used as a concatenator, it will not appear in the generated inline expansion code. The replacement value for the variable symbol and the concatenated string appear as one string in the inline expansion code.

The period must be used to concatenate a character string that immediately follows a variable symbol if that character string starts with a letter, digit, left parenthesis, or period. Some examples of this are:
\&Z.BC
\&Z. 12
\&Z. \((5,6)\)
\&Z..BC

If the replacement value for the variable symbol \(\& Z\) is 12 , the values generated in the inline expansion code would be:

12BC
1212
12(5,6)
12.BC

The opposite combination reproduces the intended concatenation period in the inline expansion code. If you code a character before a variable symbol, don't use a period to concatenate the character with the variable symbol. The period, in this particular combination, is not considered to be a concatenator. A character coded before a variable symbol does not have to be concatenated with the variable symbol; the period is considered to be part of the character code and is generated as such. Take each previous example and switch the variable symbol and the characters:

BC.\&Z
12.\&Z
\((5,6) . \& Z\)
BC..\&Z
If \(\& Z\) has a replacement value of 12 , the following would be generated inline:
BC. 12
12.12
\((5,6) .12\)
BC.. 12
The period will not be generated, however, if the character coded before the variable symbol is contained within quotes. The following is the proper way to concatenate a variable symbol prefixed with a character string if the period is used:
'BC'. \& Z'
'12'.'\&Z'
'(5,6)'. \& \& '
'BC'.'\&Z'
However, it isn't necessary to concatenate a variable symbol with a prefixed character. If you code:

BC\&Z
12\&Z
(5,6)\&Z
BC.\&Z
and \(\& Z\) equals 12 , then the following would be generated:
BC12
1212
\((5,6) 12\)
BC. 12

You do not need a period after a variable symbol to indicate concatenation, if the variable symbol is followed by another variable symbol or a special character other than a left parenthesis or a period. Some examples of this are:
\&A\&B
\(\& A+23\)
\(\& A \triangle B\)
\(\& A=23\)
You could use periods as concatenators in these examples with no adverse side effects.
If \&A equals TAG and \&B equals 1 , then the following is generated inline:
TAG1
TAG+23
TAG \(\triangle B\)
\(T A G=23\)
There are really only two items that you can concatenate with variable symbols: characters and other variable symbols. When concatenating variable symbols with variable symbols, the period is optional and, when certain combinations of characters are concatenated with a variable symbol, the period is necessary.

Each format uses a different method for coding symbolic parameters to reference positional parameters, and this relates back to differences in the parameter-specifications between the PROC and MACRO. The PROC specifies positional parameters by indicating a variable symbol in operand 1 and the number of positional parameters in the call in operand 2 . The variable symbol in operand 1 of the PROC statement is the symbolic parameter used in the body to reference positional parameters in the call. In addition to coding the symbolic parameters, you must also give the position of the parameter in parentheses immediately following the symbolic parameter: \&pos(n). You do not give a positional reference after the symbolic parameter when referencing positional parameters in a MACRO body. The MACRO works differently because the prototype statement has to give a different variable symbol for every positional parameter in the call. To reference a positional parameter from a MACRO body, the symbolic parameter that you use is the variable symbol in the prototype statement that represents the desired positional value. This means you must keep track of all the variable symbols used to represent positional parameters, while with the PROC, you only require one variable symbol for the symbolic parameter. However, you can use the system variable symbol (\&SYSLIST) in a macro to reference by position. (See 26.2.)

Symbolic parameter references to keyword parameters and symbolic parameter references to the label field of the call are the same for the PROC and MACRO. The symbolic parameter used to reference a keyword parameter in the call is the \&key portion of the variable symbol used in the heading to represent the keyword parameter. And the symbolic parameter used to reference the label field of a call instruction is the variable symbol used as a labelargument in the heading. These symbolic parameters are used the same way for both formats because the mechanics for coding them in each heading are the same.

The details of how to use symbolic parameters in model statements in the PROC and the MACRO are given in Sections 25 and 26. PROC design of call instructions is encouraged because it is easier and because most of the call instructions designed by Sperry Univac are PROCs. Model statements using symbolic parameters are shown in Figure 24-4. More detailed examples of PROCs and MACROs are given in Section 30.




\section*{25. PROC Format}

\subsection*{25.1. BASIC PROC DESIGN}

The most basic type of PROC that you can design is one that requires no parameters from the call, no label, and no positional or keyword parameters in the operand field. All that is required is a mnemonic in the operation field.
\begin{tabular}{c|l|l} 
LABEL & \(\triangle\) OPERATION \(\triangle\) & OPERAND \\
\hline & ADD1 &
\end{tabular}

When this type of call is used, it generates the same sequence of instructions with no parameter replacement. The call instruction ADD1 is designed to generate the following code every time it is used in a source program:


The design structure of a PROC that accomplishes this type of basic inline expansion is:
\begin{tabular}{l|l|l} 
LABEL & \(\triangle\) OPERATION \(\triangle\) & \\
\hline \multirow{4}{*}{ call-name } & PROC & \\
& NAME & \\
& mnemonic-code & operands \\
& \(\cdot\) & \(\cdot\) \\
& \(\cdot\) & \(\cdot\) \\
& mnemonic-code & operands \\
& END &
\end{tabular}

The PROC and NAME statements make up the heading of the PROC and must always be coded in the order shown. You use the PROC statement to identify the beginning of a macro definition in PROC format and the NAME statement to assign a call-name to the PROC. The call-name is coded in the label field of the NAME statement and is a 1-to 8-character symbol (it cannot be a variable symbol) defining the mnemonic operation code by which the macro defintiion may be referenced. The call-name must be unique. It may not be the same as any Sperry Univac mnemonic operation code or any call-name in your own library. (The only way that you can duplicate a call-name is if you override the established call-name with the OPSYM directive. See 16.2.)

After the NAME statement is the body that contains the model statement and then the trailer, an END statement that indicates the end of the PROC. The model statements in the body are the source code statements that are generated when you use the call-name in your program. If you don't require parameter replacement, the model statements could be any BAL instruction, assembler directive, or call instruction except END, ICTL, or ISEQ.

The model statements for the ADD1 call are the BAL instructions that are generated every time ADD1 is used. A completely designed ADD1 PROC is as follows:
\begin{tabular}{l|l|l} 
LABEL & \(\triangle\) OPERATION \(\triangle\) & \\
\hline \multirow{4}{*}{ ADD1 } & PROC & \\
& NAME & \\
& L & \\
& A & 13,PAY \\
& ST & 13, RAISE \\
& END & 13, TOTAL
\end{tabular}

Although the basic PROC design that accomplishes direct instruction substitution saves the programmer time and effort, the most valuable role of the macro definition in BAL is variable parameter replacement. Variable parameter replacement allows you to vary the value of the label, operation, or operand field of any model statement by using the parameters submitted with each call. This means that you can design the ADD1 example PROC so that it accepts values from the call line and replaces the PAY, RAISE, and TOTAL operands of the model statemens with the call line values. To accomplish parameter replacement in model statements, you indicate the fields that are variable by using symbolic parameters.

The symbolic parameter is the type of variable symbol used to indicate variable parameter replacement directly from the call line to the body. You can use symbolic parameters in the label, operation, or operand field of model statements to indicate parameter replacement. If you wanted the PAY, RAISE, and TOTAL operands of the ADD1 example to be variable, you would code symbolic parameters for those operands. The symbolic parameters in the model statements reference the values in the call through the PROC statement, and no symbolic parameter may be used in a model statement unless it also appears in the PROC statement. The value referenced in the call line replaces the symbolic parameter, and the manner in which you reference the parameters in the call depends on the kinds of parameters you design the call to have.

As shown in Figure 22-1, comments or instructions within a PROC call will be shifted one space beyond the last operand when they are assembled. This permits a maximum amount of space for comments on instructions that generate variable symbols.

\subsection*{25.2. REFERENCING POSITIONAL PARAMETERS IN THE CALL}

You can define the call to submit values to the PROC body via positional parameters. This is done by indicating a variable symbol in operand 1 of the PROC statement and by indicating the total number of positional parameters that can appear in the call in operand 2 of the PROC statement:


The \&pos variable symbol is the symbolic parameter used in the body of the PROC to reference positional parameters in the call instruction. Following the symbolic parameter is a decimal number in parentheses ( \(\& \operatorname{pos}(n))\) that references the positional parameter in the call. For instance:
\& pos(1) references positional parameter 1 in the call.
\&pos(2) references positional parameter 2 in the call.
\&pos(3) references positional parameter 3 in the call.
You can reference a positional parameter from the label, operation, or operand field of a model statement, and the value coded in the referenced position in the call line is generated in place of the symbolic parameter. If an omitted positional parameter is referenced, a null character string is generated in place of the symbolic parameter that made the reference. The following example shows the PROC source code and inline expansion code for an ADD2 call instruction that is designed to submit three positional parameters.


Operand 1 of the PROC statement indicates the variable symbol \&TAG is used as the symbolic parameter reference in the body, and operand 2 indicates that there can be three positional parameters in the call. The NAME statement assigns the call-name ADD2 as the mnemonic to call the PROC. The body is a model for a procedure that adds two numbers and stores the result in a main storage location. The two numbers are picked up from positional parameter 1 of the call instruction, which is someone's pay, and positional parameter 2, which is their raise. The main storage location is picked up from positional parameter 3 of the call instruction. (One of the requirements for using this call instruction is that the user supply a DS statement with a symbol the same as that of positional parameter 3 for the PROC to store the result.) The first model statement is a load instruction that uses a variable symbol in operand 2 to reference positional parameter 1 in the call instruction. The PROC generates the load instruction with a full-word fixed-point literal value of 450 in operand 2. The add instruction is generated with a 40 in operand 2, and the main storage address TOTAL is generated in operand 2 of the store instruction.

\subsection*{25.3. REFERENCING KEYWORD PARAMETERS IN THE CALL}

Instead of having the call submit values to the PROC body via positional parameters, you can use keyword parameters. This is done by using keyword parameter variable symbols starting in operand 3 of the PROC statement. Commas are used in operands 1 and 2 to indicate there are no positional parameters in the call (and key is the keyword name):
\begin{tabular}{l|l|c} 
LABEL & \(\triangle\) OPERATION \(\Delta\) & OPERAND \\
\hline & PROC & \({ }^{\prime}, \& k e y_{1}=, \ldots, \& k e y_{m}=\)
\end{tabular}

Since a variable symbol can only be eight characters long and we've used two positions with the ampersand and equal sign, the keyword name portion of the variable symbol can only be six characters long. But the keyword name in the call can exceed six characters and still be accepted by the PROC. However, anything after six characters is ignored by the PROC; it recognizes only the first six characters as the true keyword name.

The symbolic parameter used in the body of the PROC to reference keyword parameters in the call is the variable symbol indicated in the PROC statement, without the equal sign (\&key).

For instance:
\&PAY references keyword parameter \(\mathrm{PAY}=\) value in the call.
\&RAISE references keyword parameter RAISE=value in the call.
\&SAVE references keyword parameter SAVE=value in the call.

You can reference a keyword parameter from the label, operation, or operand field of a model statement, and the value after the equal sign in the call line will be generated in place of the symbolic parameter. The following example shows the PROC source code and inline expansion code for an ADD3 call instruction that is designed to submit three keyword parameters:


Operands 3 through 5 of the PROC statement indicate that there can be three different keyword parameters in the call with the keyword names of PAY, RAISE, and SAVE. The NAME statement assigns the call-name ADD3 as the mnemonic to call the PROC. (The body of this PROC is designed to perform the same function as the ADD2 example PROC.) The symbolic parameter \&PAY in operand 2 of the first model statement references the keyword parameter PAY in the call, and since PAY \(=450\), the value 450 is substituted in operand 2 of this model statement. The same processing takes place with symbolic parameters \&RAISE and \&SAVE.

You can design a PROC so that a preselected value is generated for a symbolic parameter that references an omitted keyword parameter in the call. Otherwise, symbolic parameters that reference omitted keyword parameters receive the value of a null character string. The default value for a keyword parameter is coded after the equal sign of the variable symbol in the PROC statement.

The following example shows a PROC with a default value indicated in the PROC statement:


The call instruction doesn't use the RAISE keyword parameter so the default value of 40 indicated in the PROC statement is generated in the inline expansion code.

Another type of PROC is one with mixed-mode parameters. This PROC is designed to accept both positional and keyword parameters from the call. The format of the PROC statement for designing mixed-mode calls is:
\begin{tabular}{c|c|c} 
LABEL & \(\triangle\) OPERATION \(\triangle\) & OPERAND \\
\hline & PROC & \({\text { \&pos, } \mathrm{n}, \& k e y_{1}=, \ldots, \& k e Y_{m}=}\)
\end{tabular}

We could design the ADD4 example PROC to have the call submit the \&PAY symbolic parameter as a positional parameter and the \&SAVE and \&RAISE symbolic parameters as keyword parameters, with RAISE having a default value of 40:


The following example shows what happens if you have a default value indicated in the PROC statement and submit a value for the keyword in the call instruction; the value in the call overrides the value in the PROC heading:


\subsection*{25.4. REFERENCING SUBPARAMETERS IN THE CALL}

Another way to generate values in a field of a model statement is by referencing values in a parameter sublist. The parameter sublist is a list of subparameters that are subordinate to either a positional or keyword parameter. When you use a sublist, you can submit multiple parameter values from a single operand in the call. No coding is required in the PROC statement to support a sublist in a call line. It is a matter of referencing the sublist from a model statement by using a symbolic parameter with a sublist reference. The symbolic parameter reference to a subparameter in a positional parameter sublist is:
\(\& \operatorname{pos}(n, x)\)
where:
\&pos
Is the variable symbol used in operand 1 of the PROC statement to represent positional parameters.
n
Is the number of the positional parameter in the call.
x
Is the position of the subparameter in the sublist. (All subparameters are referenced by position.)

Sublists for positional parameters must be coded within parentheses in the operand field of the call:
\[
\left(P_{1,1}, P_{1,2, \ldots,} P_{1, n}\right), \ldots,\left(P_{n, 1}, \ldots, P_{n, x}\right)
\]

The following example shows a PROC referencing a positional parameter sublist in the call line:


The symbolic parameter reference to a subparameter in a keyword parameter sublist is:
\& key \((x)\)
where:
\&key
Is the variable symbol in the PROC statement.
x
Is the number of the position of the subparameter in the sublist.
Sublists for keyword parameters must be coded within parentheses after the equal sign in the operand field of the call:
\[
k_{1}=\left(p_{1}, \ldots, p_{x}\right), \ldots, k_{n}=\left(p_{1}, \ldots, p_{x}\right)
\]

The following example shows a PROC referencing a keyword parameter sublist in the call line:

PROC SOURCE CODE


In addition to having the individual subparameters in a call generated in model statements, you can have the entire sublist generated. You do this by referencing the positional or keyword parameter with no reference to its subparameters. Simply use the symbolic parameter as you normally would reference a keyword or positional parameter; and its associated sublist, including the parentheses, will be generated. If a SET symbol appears in the operand entry of a macro instruction, attribute information is not provided and the operand may not be accessed as a sublist.

\subsection*{25.5. MULTIPLE PROC NAMES AND POSITIONAL PARAMETER 0}

The split heading characteristic of the PROC permits another means of parameter modification. The parameter value is submitted by varying the mnemonic name in the operation field of the call. You can design a PROC so it may be called by many mnemonic names, and each name represents a different parameter value. This is easily done in the PROC because the NAME statement separates the call-name from the parameters in the PROC statement and therefore leaves the operand field of the NAME statement open for use. The PROC utilizes the operand field of the NAME statement for assigning a value to the call-name:
\begin{tabular}{c|l|l} 
LABEL & \(\triangle\) OPERATION \(\triangle\) & \\
\hline call-name & NAME & pos-0
\end{tabular}
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 (\&pos(0)). You can vary the value for positional parameter 0 by using multiple NAME statements. Each NAME statement has a different call-name and a value in the operand field for positional parameter 0 . A symbolic parameter referencing positional parameter 0 receives the pos-O value from the NAME statement whose call-name is used in the operation field of the call. All NAME statements must appear directly after the PROC statement and before any model statements, including comments.

We could design the ADD2 example PROC to have to have several different call-names and, each time a different call-name is used, the register number for operand 1 of the model statements is changed:


INLINE EXPANSION CODE
\(\begin{array}{ll}\text { L } & 11,=F^{\prime} 450^{\prime} \\ \text { A } & 11,=F^{\prime} 40^{\prime} \\ \text { ST } & 11, \text { TOTAL }\end{array}\)

\subsection*{25.6. THE LABEL ARGUMENT}

The label-argument is used to reference the symbol coded in the label field of a call instruction. To establish a label-argument, you must code a variable symbol in the label field of the PROC statement. The format of the PROC statement with a label-argument is as follows:
\begin{tabular}{c|c|c} 
LABEL & DOPERATION \(\triangle\) & OPERAND \\
\hline \&symbol & PROC & \&pos,n, \&key \(_{\mathbf{1}}=, \ldots, \& \mathrm{key}_{\mathbf{m}}=\)
\end{tabular}

The variable symbol that is coded in the label field of the PROC statement is used as the reference to the symbol in the label field of the call instruction. This variable symbol is used to take the label field from a call instruction and generate it in a model statement. Any model statement can have a label-argument. A label-argument is useful when you use a label in a PROC and you expect several copies of the inline expansion code to be in one program. The user can change the name of the label by changing the symbol in the label field of the call.

The following PROC uses a label-argument. The purpose of this PROC is to add the number of salaries indicated in positional parameter 1 and located where indicated by keyword parameter RAISE. The results are stored in the location indicated by keyword parameter TOTAL, and control is returned to the user program at the location indicated by keyword parameter OUT.


\section*{26. MACRO Format}

\subsection*{26.1. BASIC MACRO DESIGN}

A basic MACRO does not perform variable parameter substitution and, therefore, does not require any values to be passed from the call instruction. The design structure of a MACRO that accomplishes this type of basic inline expansion is:
\begin{tabular}{l|l|l} 
LABEL & \(\triangle\) OPERATION \(\triangle\) & \\
\hline \multirow{5}{*}{} & OPERAND \\
& MACRO & \\
& call-name & \\
& mnemonic-code & operands \\
& \(\cdot\) & \(\cdot\) \\
& mnemonic-code & operands \\
& MEND &
\end{tabular}

The statements in a MACRO must always be coded in the order shown. First is the MACRO statement which indicates the beginning of a macro definition in MACRO format. Next is the prototype statement, which is where you code the call-name. Then, you code the model statements, which can be any BAL instruction, assembler directive, or call instruction except END, ICTL, or ISEO. The last statement in a MACRO is the MEND statement, which indicates the end of the definition.

If we take the ADD1 PROC shown in Section 25 and design an ADD1 MACRO, it appears as follows:
\begin{tabular}{l|l|l} 
LABEL & OOPERATION \(\triangle\) & \\
\hline & MACRO & \\
& ADD1 & \\
& L & \\
& A & 13,PAY \\
& ST & 13,RAISE \\
& MEND & 13,TOTAL \\
& &
\end{tabular}

The ADD1 example MACRO produces the same inline expansion code as the ADD1 example PROC:
\begin{tabular}{l|l|ll} 
LABEL & \(\Delta\) OPERATION \(\triangle\) & & OPERAND \\
\hline & L & 13,PAY \\
& A & 13,RAISE \\
& ST & 13,TOTAL
\end{tabular}

As shown in Figure 22-1, comments on instructions within a MACRO call will be shifted one space beyond the last operand when they are assembled. This permits a maximum amount of space for comments on instructions that generate variable symbols.

\subsection*{26.2. REFERENCING POSITIONAL PARAMETERS IN THE CALL}

Designing a MACRO to reference positional parameters in the call is a little different from the way it is done in the PROC. In MACRO design, the prototype statement must indicate a variable symbol for each positional parameter to be coded in the call. Positional parameter variable symbols are coded in the prototype statement as follows:
\begin{tabular}{|c|c|c|}
\hline label & \(\triangle\) Operation \(\triangle\) & operand \\
\hline & call-name & \& pos \(_{1}, \ldots, \&\) Pos \(_{n}\) \\
\hline
\end{tabular}

The variable symbol representing a positional parameter in the call is used as the symbolic parameter to reference that positional parameter. You can reference a positional parameter from the label, operation, or operand field of a model statement, and the value coded in the referenced position in the call is generated in place of the symbolic parameter. If an omitted positional parameter is referenced, a null character string is generated in place of the symbolic parameter that made the reference.

The following example shows the ADD2 example PROC given in Section 25 recoded in MACRO format:


You can also reference the positional parameter values in the call by position rather than by using the symbolic parameters coded in the prototype statement. To do this, you must use the system variable symbol \(\&\) SYSLIST. Instead of coding the positional parameter variable symbol for the symbolic parameter reference, you code:
\&SYSLIST(n)
where:
n
Is the number of the positional parameter in the call and can be an expression that is a self-defining term or a SETA symbol. (SETAs are discussed in Section 27.)

If you miscount the positional parameter string in the call and \(n\) is greater than the actual number of parameters that are supposed to be in the call, then a null character string is generated in place of \&SYSLIST(n). When you use \&SYSLIST, it isn't necessary to have positional parameter variable symbols in the heading. \&SYSLIST references the call instruction, not the heading. The function of \&SYSLIST is to provide the MACRO designer with the option to reference positional parameters by position, similar to the way it is done in the PROC. However, \&SYSLIST does not allow you to reference keyword parameters by position as you could do in the PROC. In the PROC, you could use \&pos( \(\mathrm{n}+1\) ) and continue right on through into the keyword parameters in the parameter-list. This won't work with \(\&\) SYSLIST because \(\&\) SYSLIST only references positional parameters.

The following example shows the ADD2 example MACRO redesigned with \&SYSLIST symbolic parameter references:

MACRO SOURCE CODE
CALL INSTRUCTION


\subsection*{26.3. REFERENCING KEYWORD PARAMETERS IN THE CALL}

The MACRO references keyword parameter values in the call in the same way as the PROC. A keyword parameter reference is made by a symbolic parameter that consists of the \&key portion of the keyword variable symbol. If the call is to have only keyword parameters, the prototype statement is coded as follows:
\begin{tabular}{l|l|l} 
LABEL & \(\triangle\) OPERATION \(\Delta\) & OPERAND \\
\hline & call-name & \&key \(_{1}=, \ldots, \& \mathrm{key}_{\mathrm{m}}=\)
\end{tabular}

You can reference a keyword parameter from the label, operation, or operand field of a model statement and the value after the equal sign in the call will be generated in place of the symbolic parameter.

The following is the ADD3 example PROC, shown in Section 25, recoded in MACRO format:


If you want any of the keyword parameters in the call to have a default value, you code that value after the equal sign of the keyword variable symbol in the prototype statement. Whenever a keyword parameter in the call is omitted, the symbolic parameter receives the value given the keyword variable symbol. A symbolic parameter referencing a keyword parameter that doesn't have a default value receives the value of a null character string.

To design a MACRO that references positional and keyword parameters in the call, you code the positional symbolic parameters before the keyword symbolic parameters in the prototype statement. The prototype statement for a mixed-mode MACRO is as follows:
\begin{tabular}{c|c|c} 
LABEL & \(\triangle\) OPERATION \(\triangle\) & OPERAND \\
\hline & call-name & \&pos \(_{1}, \ldots, \&\) Pos \(_{n}, \& k e y_{1}=, \ldots\), key \(_{m}=\) \\
& &
\end{tabular}

The following example shows the ADD5 example PROC, shown in Section 25, redesigned in MACRO format:


\subsection*{26.4. REFERENCING SUBPARAMETERS IN THE CALL}

Like the PROC, the MACRO does not require support from the heading to use sublists in the call. It is a matter of referencing the sublist from a model statement by using a symbolic parameter or \&SYSLIST with a sublist reference. The \&SYSLIST reference to a subparameter in a positional parameter sublist is:

\section*{\&SYSLIST( \(\mathrm{n}, \mathrm{x}\) )}
where:
n
Is the number of the positional parameter in the call.
x
Is the number of the subparameter in the sublist.
The following example shows the ADD7 example PROC, shown in Section 25, recorded in MACRO format:


The symbolic parameter reference to a subparameter in a keyword parameter sublist for a MACRO is the same as for the PROC:

\section*{\&key(x)}
where:
\&key
Is the variable symbol in the prototype statement.
x
Is the number of the subparameter in the sublist.
The following example shows the ADD8 example PROC, shown in Section 25, redesigned in MACRO format:


If you reference a positional or keyword parameter with a sublist and do not include a reference to a subparameter within the list, you will generate the entire sublist, including parentheses, in place of the symbolic parameter. The same thing happens in a PROC. If a SET symbol appears in the operand entry of a macro instruction, attribute information is not provided and the operand may not be accessed as a sublist.

\subsection*{26.5. THE LABEL ARGUMENT}

The label argument for a MACRO is used the same way it is used in the PROC. To establish the label argument, you must code a variable symbol in the label field of the prototype statement. The format of the prototype statement with a label argument is as follows:
\begin{tabular}{c|c|c} 
LABEL & \(\triangle\) OPERATION \(\triangle\) & OPERAND \\
\hline \&symbol & call-name & \&pos \(_{1}, \ldots, \&\) pos \(_{n}, \& k e y_{1}=, \ldots, \& k e y_{m}=\)
\end{tabular}

The following MACRO uses a label argument. This example MACRO is the PLUS example PROC recoded in MACRO format (25.6).

CALL INSTRUCTION


\section*{27. Conditional Assembly}

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 assembly statements are used by the programmer to direct the asssembler 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.

Table 27-1 lists the function of each conditional assembly statement.

Table 27-1. Conditional Assembly Language Statements (Part 1 of 2)
\begin{tabular}{|c|c|c|}
\hline Statement & Function & General Usage \\
\hline ACTR & Sets a conditional assembly loop counter & \multirow[t]{5}{*}{Branching} \\
\hline \begin{tabular}{l}
AGO \\
*AGOB \\
*GOTO
\end{tabular} & An unconditional branch & \\
\hline \[
\begin{aligned}
& \text { AIF } \\
& { }^{*} \text { AIFB }
\end{aligned}
\] & A conditional branch & \\
\hline ANOP *LABEL & Provides a branch destination point for a location that already contains a symbol or variable symbol & \\
\hline MEXIT & Stops processing of macro definitions & \\
\hline DO & Defines starting point of the code and the number of times it is to be generated & \multirow[t]{2}{*}{Used for defining the range for repetitive code} \\
\hline ENDO & Defines the end of the code to be repeated & \\
\hline \begin{tabular}{l}
MNOTE \\
PNOTE
\end{tabular} & Generates messages in macro definitions or program source code & Used for generating messages \\
\hline
\end{tabular}

\footnotetext{
*Alternate mnemonic
}

Table 27-1 Conditional Assembly Language Statements (Part 2 of 2)
\begin{tabular}{|l|l|l|}
\hline Statement & \multicolumn{1}{|c|}{ Function } & \multicolumn{1}{c|}{\begin{tabular}{c} 
General Usage
\end{tabular}} \\
\hline LCL & Declares a general-purpose local set symbol & \begin{tabular}{l} 
Used for declaring set symbols \\
that are to be used only inside \\
the macro definition that is \\
declaring the set symbol
\end{tabular} \\
\hline LCLA & Declares an arithmetic local set symbol & \begin{tabular}{l} 
Declares a Boolean local set symbol
\end{tabular} \\
\hline LCLB & Declares a character local set symbol & \begin{tabular}{l} 
Used for declaring set symbols \\
that are to be used not only in \\
the macro definition in which \\
the set symbol is declared, but \\
also outside the macro definition \\
in other macro definitions
\end{tabular} \\
\hline GBL & Declares a general-purpose global set symbol & \begin{tabular}{l} 
Declares a Boolean global set symbol
\end{tabular} \\
\hline GBLB & Declares a character global set symbol & \begin{tabular}{l} 
Used to assign values to arithmetic, \\
Boolean, or character set symbol
\end{tabular} \\
\hline GBLC & \begin{tabular}{ll} 
Assigns an arithmetic or character string value \\
to a set symbol
\end{tabular} & \begin{tabular}{l} 
Assigns an arithmetic value to a set symbol
\end{tabular} \\
\hline SET & \begin{tabular}{l} 
Assigns a binary value of 0 (false) or 1 (true) \\
to a set symbol
\end{tabular} & \begin{tabular}{l} 
Assigns a character value to a set symbol
\end{tabular} \\
\hline SETB & &
\end{tabular}
*Alternate mnemonic

\subsection*{27.1. SET SYMBOLS}

Set symbols are a type of variable symbol (Appendix G). 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 is eight)
- If the ampersand is omitted, the assembler interprets the character string as a symbol and not as a set symbol.

The following are valid set symbols:
\& C
\&A1
\&PARAM
The following are not valid set symbols for the reasons stated:
CAT
Valid for an ordinary symbol but not as a set symbol; no leading ampersand.
\&1
First character after \& is not alphabetic.
\&S12345678
There are too many characters in the string (maximum length, including \&, is eight characters).

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.

Set symbols must be declared after macro prototype or NAME statements and before being referenced.

\subsection*{27.1.1. Local Set Symbols}

A local set symbol is available for use only in the macro definition in which it is declared. Four statements are available for declaring 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.

The basic format for a local set symbol declaration is:
\(\left.\begin{array}{c|l|l}\text { LABEL } & \text { LOPERATION } \Delta & \\
\hline \text { unused } & \begin{array}{l}\text { LCL } \\
\text { LCLA } \\
\text { LCLB } \\
\text { LCLC }\end{array}\end{array}\right\}\)\begin{tabular}{c}
\(\mathrm{s}_{1}\left[, \mathrm{~s}_{2}, \ldots, \mathrm{~s}_{n}\right]\) \\
\end{tabular}
where:
LCL
Declares a general-purpose local set symbol.

\section*{LCLA}

Declares an arithmetic local set symbol.

\section*{LCLB}

Declares a Boolean local set symbol.

\section*{LCLC}

Declares a character local set symbol.
```

$\mathbf{s}_{1}, \mathbf{s}_{2}, \ldots, \mathbf{s}_{\boldsymbol{n}}$
Are set symbol names.

```

The operand field of the local set declaration may contain one or more set symbol names. A local 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.

Examples:
\begin{tabular}{lll} 
LABEL & \(\triangle O P E R A T I O N \Delta\) \\
1 & 10 & 16
\end{tabular}
\begin{tabular}{lll}
1. \\
2. & LCLA & \(\varepsilon A, \varepsilon B\) \\
3. & LCLB & \(\varepsilon B I G\) \\
LCLC & \(\varepsilon B I G 3\)
\end{tabular}
1. Declares arithmetic local set symbols \(\& A\) and \(\& B\).
2. Declares a Boolean local set symbol \&BIG.
3. Declares a character local set symbol \&BIG3.

\subsection*{27.1.2. Global Set Symbols}

Global set symbols are initialized only once and are used to pass values back and forth between macro definitions. A global set symbol is available to all macro definitions in which it is also declared.

Four statements are available for declaring 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.

The basic format for a global symbol declaration is:
\(\left.\begin{array}{c|l|l}\text { LABEL } & \text { } \triangle \text { OPERATION } \Delta & \\
\hline \text { unused } & \begin{array}{l}\text { GBL } \\
\text { GBLA } \\
\text { GBLB } \\
\text { GBLC }\end{array}\end{array}\right\}\)\begin{tabular}{l}
\(s_{1}\left[, s_{2}, \ldots, s_{n}\right]\) \\
\end{tabular}
where:
GBL
Declares a general-purpose global set symbol.

\section*{GBLA}

Declares an arithmetic global set symbol.

\section*{GBLB}

Declares a Boolean global set symbol.

\section*{GBLC}

Declares a character global set symbol.
\(\mathbf{s}_{1}, \mathbf{s}_{2}, \ldots, \mathbf{s}_{\mathrm{n}}\)
Are set symbol names.
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.

Examples:
\begin{tabular}{|c|c|c|c|}
\hline LABEL & \multicolumn{2}{|l|}{\(\triangle O P E R A T I O N \triangle\)} & OPERAND \\
\hline 1 & 10 & 16 & \\
\hline 1. & GBL & \(\varepsilon B R\) & \\
\hline 2. & GBLA & \&SET1, ESET2 & \\
\hline 3. & GBLB & \&BUT & \\
\hline 4.1 & GBLC & \&GLB & \\
\hline
\end{tabular}
1. Declares a general-purpose global set symbol.
2. Declares arithmetic global set symbols.
3. Declares a Boolean global set symbol.
4. Declares a character global set symbol.

\subsection*{27.1.3. Set Symbol Value Assignment}

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.

\subsection*{27.1.4. SET Statement}

The SET statement can be used to assign either an arithmetic or character string value to a variable symbol declared by an LCL or GBL statement.

The format of the SET statement is:
\begin{tabular}{l|l|l} 
LABEL & DOPERATION \(\triangle\) & \\
\hline\(\& s\) & SET & \(\left.\begin{array}{l}\mathrm{a} \\
\mathrm{c}\end{array}\right\}\)
\end{tabular}
where:
\&s
Is a set symbol declared by LCL or GBL.

\section*{SET}

Defines the operation.
a
Is a valid arithmetic expression.
c
Is a valid character expression.

When the operand of the SET statement contains an arithmetic expression, the value of the expression may range from \(-10^{8}-^{1}\) to \(+10^{8}-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 a 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 two characters \({ }^{* *}\) represent the logical product AND, the two characters ++ represent the logical sum OR, and the two characters - - represent the logical difference 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:
\begin{tabular}{|c|c|}
\hline \multicolumn{3}{|c|}{ AND } \\
\hline\(A^{* *} B\) & Result \\
\hline 1 & 1
\end{tabular}
\begin{tabular}{|c|c|}
\hline \multicolumn{3}{|c|}{ OR } \\
\hline\(A++B\) & Result \\
\hline 1 & 1 \\
1 & 0 \\
0 & 1 \\
0 & 0
\end{tabular}
\begin{tabular}{|c|c|}
\hline \multicolumn{3}{|c|}{ XOR } \\
\hline\(A--B\) & Result \\
\hline 1 & 1 \\
1 & 0
\end{tabular}\(] 0\)

The three relational operators are the equal ( \(=\) ) operator, the greater than \((>)\) operator, and the less than \((<)\) operator.

\section*{where:}
\(=\)
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 character or logical expression is arithmetic, the expression may be used as a term in an arithmetic expression.

Operator priority is shown in Table 27-2.

Table 27-2. Operator Priority
\begin{tabular}{|l|c|}
\hline Operator & Hierarchy \\
\hline\(* /\) & 6 \\
\(11, * .1\) & 5 \\
,+- & 4 \\
\(* *\) & 3 \\
,--++ & 2 \\
\(<>=\) & 1 \\
\hline
\end{tabular}

Examples:

LABEL \(\triangle O P E R A T I O N \triangle\) OPERAND 101016
\begin{tabular}{lll} 
1. \\
2. 2 EARK & SET & \({ }^{\prime} A N I M '\) \\
ENUM & SET & 6
\end{tabular}
1. The SET symbol \&ARK is assigned the value of ANIM.
2. The SET symbol \&NUM is assigned the value of 6 .

\subsection*{27.1.5. SETA Statement}

The SETA statement assigns an arithmetic value to a variable symbol that was declared by an LCLA or GBLA statement.

The format of the SETA statement is:
\begin{tabular}{l|l|l} 
LABEL & DOPERATION \(\triangle\) & OPERAND \\
\hline\(\& s\) & SETA & a
\end{tabular}
where:
\&s
Is a set symbol declared by either LCLA or GBLA.

\section*{SETA}

Defines the operation.
a
Is a valid SETA term or an arithmetic combination of valid SETA terms.
A valid SETA term is:
- a self-defining term;
- 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 in Table 27-2. The value of a SETA expression may range from \(-2^{23}\) to \(\mathbf{2 n}^{23} \mathbf{- 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 an unsigned decimal integer with leading zeros removed. This decimal value is then substituted for the SETA symbol. If the value of the SETA symbol is zero, a single zero is substituted.

Examples:
\begin{tabular}{lll} 
LABEL & \(\triangle\) OPERATION \(\Delta\) \\
1 & 10 & 16
\end{tabular}
\begin{tabular}{lll} 
1. & \begin{tabular}{lll} 
EART & SETA & 5 \\
ELOC & SETA & 7 \\
3. & \(7 E R\) & SETA
\end{tabular} & EART \(+\varepsilon L O C\)
\end{tabular}
1. The SETA symbol \&ART is assigned a value of 5 .
2. The SETA symbol \&LOC is assigned a value of 7 .
3. The SETA symbol \&HER is assigned a value of 12.

\subsection*{27.1.6. SETB Statement}

The SETB or set Boolean value statement may be used to assign a binary value of zero or one to a variable symbol which was declared by an LCLB or GBLB statement. The format of the SETB statement is:
\begin{tabular}{l|l|l} 
LABEL & \(\triangle\) OPERATION \(\triangle\) & \\
\hline\(\& s\) & SETB & b
\end{tabular}
where:
\&s
Is a set symbol declared in either LCLB or GBLB.

\section*{SETB}

Defines the operation.
b
Is a valid logical expression that must be enclosed in parentheses or a 0 or 1 enclosed in parentheses.

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 expressions may consist of a single term or logical combination of terms.

The permissible terms are:
- a SETB arithmetic relational expressions;
- a SETB character relational expression; and
- a SETB symbol.

The SETB logical operators that may be used to combine the terms are AND, OR, and NOT. The logical expression must not contain two terms in succession. Two operators may appear in succession if the first operator is either AND or OR, and the second operator is NOT. Only the operator NOT is allowed prior to the first term of the expression.

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:
- 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:
\[
\begin{aligned}
& \mathrm{OR}=1 \\
& \text { AND }=2 \\
& \text { NOT }=3
\end{aligned}
\]

Therefore, NOT is performed prior to AND, and AND is performed prior to OR.
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 value +0 and +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 are substituted. In a character expression, the character values 1 and 0 are substituted.

Examples:
LABEL \(\triangle O P E R A T I O N \triangle\) OPERAND
1016
\begin{tabular}{lll} 
1. & \(\left.\begin{array}{lll}\text { ECONT } & \text { SETB } & \text { (L'\&TO EQ 4) } \\
\text { 2. } & \end{array}\right)\) (1)
\end{tabular}
1. If the expression L'\&TO EO 4 is true, the symbol \&CONT is assigned a value of 1 ; otherwise, it is assigned a value of 0 .
2. The symbol \&EXP is assigned a value of 1 .

\subsection*{27.1.7. SETC Statement}

The SETC statement may be used to assign a character value to a variable symbol that was declared by an LCLC or GBLC statement.

The format of the SETC statement is:
\begin{tabular}{l|l|l} 
LABEL & \(\triangle\) OPERATION \(\triangle\) & OPERAND \\
\hline \&s & SETC & \(c\)
\end{tabular}
where:
\&s
Is a set symbol declared by either LCLC or GBLC.

\section*{SETC}

Defines the operation.
c
Is a valid SETC operand.
A SETC operand must be a character expression. (See 27.1.8.)
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 left-most eight characters are used by the assembler.

Examples:
\begin{tabular}{lll} 
LABEL & \(\triangle O P E R A T I O N \Delta\) \\
10 & 16 & OPERAND
\end{tabular}
1. \begin{tabular}{lll} 
ETYPE & SETC & 'EEAID' \\
2. & \\
\hline
\end{tabular}
1. The symbol \&TYPE is assigned the value of \&AID.
2. The symbol \&CITY is assigned the value of CINN.

\subsection*{27.1.8. Character Expressions}

A character expression is either a character string, a character substring, or a concatenation of strings or substrings. Character expressions are used as the operand of a SET or SETC statement or as terms in a SETB, SET, AIF, or DO relational expression. Any character string is considered to be greater in value than any shorter character string. A character expression may have a length of up to 127 characters.

\subsection*{27.1.9. Subscripted SET Symbols}

Subscripted SET symbols may be defined as both global and local SET symbols. The local SET symbols previously defined were all nonsubscripted SET symbols. Subscripted SET symbols provide you with a convenient way to use a SET symbol plus a subscript to refer to many binary, arithmetic, or character values. The subscript may be any arithmetic expression that is allowed in the operand of a SETA statement in the range of 1 to the specified dimension. The subscripted SET symbol consists of a SET symbol immediately followed by a subscript enclosed in parentheses.

A SETA or SETB operand permits only five levels of parentheses.

The following are valid subscripted SET symbols:
\&INPUT(30)
\& B45723(\&A1)
\&A6B9(2+\&B1)
The following are invalid subscripted SET symbols:
\[
\begin{array}{ll}
\text { \&AB } & \text { No subscript } \\
(300) & \text { No SET symbol }
\end{array}
\]

\subsection*{27.1.9.1. Defining Subscripted SET Symbols}

To use a subscripted SET symbol, you must write in a GBLA, GBLB, GBLC, LCLA, LCLB, or LCLC instruction with a SET symbol immediately followed by an unsigned decimal integer enclosed in parentheses. The number of SET variables associated with the SET symbol is indicated by the decimal integer and is called the dimension. Every variable associated with a SET symbol is assigned an initial value that is the same as the initial value assigned to the corresponding type of nonsubscripted SET symbol. If a subscripted SET symbol is defined as global, the same dimension (decimal integer) must be used with the SET symbol each time it is defined as global.

The maximum dimension of 255 can be used with a SETA, SETB, or SETC statement. A subscripted SET symbol may be used only if the declaration was subscripted, while a nonsubscripted SET symbol may be used only if the declaration had no subscript.

\subsection*{27.2. BRANCHING}

The sequence of processing macro source code statements may be altered by branching. The assembler provides for conditional and unconditional branching.

\subsection*{27.2.1. Sequence Symbols}

A sequence symbol is used to define a branch destination point. A sequence symbol may appear in the label field of any statement that does not contain a symbol or a set symbol, except for a macro prototype statement, a local or global symbol declaration statement (LCL, LCLA, LCLB, LCLC, GBL, GBLA, GBLB, GBLC), or MACRO, PROC, NAME, ICTL, or ISEQ statement.

A sequence symbol is written in the following form: a period followed by at least one alphabetic character followed by up to six alphaunumeric characters. The following are valid sequence symbols:

D
D3
.BRNCPNT
When a sequence symbol is written in the label field of a macro instruction, statement, and the prototype (MACRO format) or PROC statements (PROC format) for that macro definition that contain a variable symbol in their label fields, the sequence symbol does not replace the variable symbol.

\subsection*{27.2.2. Unconditional Branch (AGO)}

The unconditional branch (AGO) statement unconditionally alters the sequence of source statement processing. The format is:
\begin{tabular}{l|l|l} 
LABEL & \(\triangle\) OPERATION \(\triangle\) & \\
\hline\(\left[. s_{1}\right]\) & \(\left.\begin{array}{l}\text { AGO } \\
\text { AGOB } \\
\text { GOTO }\end{array}\right\}\)
\end{tabular}\(\quad\)\begin{tabular}{ll} 
OPERAND \\
\hline
\end{tabular}
where:
AGO
Defines the operation.
. \(\mathbf{S}_{1}\)
Is a sequence symbol.
. \(\mathbf{S}_{2}\)
Is a sequence symbol defined in a source code statement.
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 of another statement in that macro definition.

Examples:


\subsection*{27.2.3. Conditional Branch (AIF)}

The conditional branch (AIF) statement conditionally alters the sequence of source statement processing. The format is:

where:
. \(\mathrm{s}_{1}\)
Is a sequence symbol.
AIF
Defines the operation.
(b)

Is a SETB logical expression enclosed in parentheses.
. \(\mathrm{S}_{2}\)
Is a sequence symbol defined in a source code statement.
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 (27.1.6) is valid in the operand field of the AIF statement except a 0 or a 1 enclosed in parentheses. The sequence symbol in the operand 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 operand. If the condition is false (a value of 0 ), the statement in the source code following the AIF statement would 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 field of another statement within that macro definition.

Examples:
\begin{tabular}{|c|c|c|c|}
\hline LABEL & \multicolumn{2}{|l|}{\(\triangle O P E R A T I O N \triangle\)} & \multirow[t]{2}{*}{OPERAND} \\
\hline 1 & 10 & 16 & \\
\hline 1. & AIF & & \\
\hline 2. . IF & AlF & & \\
\hline
\end{tabular}
1. If the value of the symbol \&BRO is zero, the next statement to be processed is \&IF.
2. If the length attributes of the symbols \(\& T O\) and \(\& F R O M\) are equal, a true (1) results and a branch is made to a statement in the source code labeled .END.

\subsection*{27.2.4. Define Branch Destination (ANOP)}

The define branch destination (ANOP) statement is provided to facilitate 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. The format is:

where:
.s
Is a sequence symbol.
ANOP
Defines the operation.
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.
Example:


If the Boolean expression in the AIF operand is true, a branch is made to the ANOP statement with the label .DEST. Since no operations are performed by ANOP, control passes immediately to the following statement, a SETC whose label field is already occupied by the variable symbol \&STATE.

\subsection*{27.2.5. Macro Definition Exit (MEXIT)}

The macro definition exit (MEXIT) statement is used when it is necessary to process only one section or operation of a macro definition rather than the entire macro definition. This statement indicates to the assembler that the processing of a macro definition should be terminated before ending normally with a MEND statement.

The format of the MEXIT statement is:


When MEXIT is used, 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 coding example of the MEXIT statement is included in 27.3.1.

\subsection*{27.3. ERROR MESSAGES AND COMMENTS}

PNOTE or MNOTE statements are used to generate error messages or comments in a macro definition or in source code statements.

\subsection*{27.3.1. MNOTE Message Statements (MNOTE)}

A MNOTE message statement is used to generate an error message. It indicates how dangerous the error is or generates a comment that supplies information. A MNOTE statement is used in a macro definition or in source code statements.

The MNOTE statement source code statement format is:
\begin{tabular}{c|l|l} 
LABEL & \(\triangle\) OPERATION \(\triangle\) & \\
\hline unused & MNOTE & OPERAND
\end{tabular}\(\quad \downarrow\)

This format can be used to 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 that occurred. The severity code is a decimal value of zero to 255 .

If you want to indicate a severity code of 1 , you leave a blank space ( \(\Delta\) ) 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. 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 do not 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 a MNOTE statement.
The following example contains a MNOTE statement that generates a message in the source code of the assembly listing, and causes the line of code to be flagged in error. The error also is listed in the diagnostics portion of an assembly listing produced by this code.

Example:


\subsection*{27.3.2. PNOTE Message Statements (PNOTE)}

A PNOTE message statement is used to generate an error message or a comment. A PNOTE statement is used in a macro definition or a source code statement.

The PNOTE source code statement format is:
\begin{tabular}{c|c|c} 
LABEL & DOPERATION \(\triangle\) & \\
\hline unused & PNOTE & \(\left\{\begin{array}{c}* \\
\left.e^{\prime}\right\}, \prime m^{\prime}\end{array}\right.\)
\end{tabular}

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 the asterisk indicates that the message is not an error.

Variable symbols can be used as operands in a PNOTE statement.

\subsection*{27.3.3. Comments Statement}

A comments statement written within a macro definition 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.

A special form of the comments statement also is available for use within macro definitions. It is used to include comments in a macro definition that are not to be generated in the output listing. This comments statement 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 comments statement form can be created by substitution for variable symbols. Substitution for variable symbols is not performed on comment lines.

Examples:


\subsection*{27.4. REPETITIVE CODE GENERATION}

A section of code can be generated one or more times. The statements DO and ENDO specify the code you want and the number of times you want it to be generated.

\subsection*{27.4.1. Define Start of Range (DO)}

The define start of range (DO) statement defines the starting point of the code and the number of times it is to be generated. The format is:
\begin{tabular}{c|l|l|} 
LABEL & \(\triangle\) OPERATION \(\triangle\) & OPERAND \\
\hline [\&varisymb] & DO & a
\end{tabular}
where:

\section*{\& varisymb}

Is an optional variable symbol.

\section*{DO}

Defines the operation.
a
Is a valid SET expression (27.1) written in a macro definition.
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 (27.4.2) 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 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 declared in the label field of the DO statement. The rules for writing variable symbols are described in Section 26. 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 (27.1.5). An example of a DO statement is shown in 27.4.2.

\subsection*{27.4.2. Define End of Range (ENDO)}

The define end of range (ENDO) statement is used to indicate the end of the range of a DO statement. The format is:
\begin{tabular}{c|l|ll} 
LABEL & \(\triangle\) OPERATION \(\triangle\) & & OPERAND \\
\hline unused & ENDO & unused
\end{tabular}

DO and ENDO statements must be paired. For every DO statement, there must be an ENDO statement to define the end of the range.

Examples:
\begin{tabular}{|c|c|c|c|c|}
\hline & \multirow[t]{2}{*}{\begin{tabular}{l}
LABEL \\
1
\end{tabular}} & \multicolumn{2}{|l|}{\(\triangle\) OPERATIONA} & OPERAND \\
\hline & & 10 & 16 & \\
\hline 1. & \multirow[t]{7}{*}{EDOI} & D0 & 5 & \\
\hline 2. & & - & & \\
\hline 3. & & - & & \\
\hline 4. & & - & & \\
\hline 5. & & ENDO & & \\
\hline 6. & & . & & \\
\hline 7. & & . & & \\
\hline 8. & \multirow[t]{4}{*}{¢D02} & D0 & 10 & \\
\hline 9. & & . & & \\
\hline 10. & & . & & \\
\hline 11. & & . & & \\
\hline 12. & \multirow[t]{3}{*}{ED03} & D0 & 3 & \\
\hline 13. & & . & & \\
\hline 14. & & . & & \\
\hline 15. & \multirow[t]{8}{*}{ED04} & D0 & 5 & \\
\hline 16. & & . & & \\
\hline 17. & & . & & \\
\hline 18. & & . & & \\
\hline 19. & & ENDO & & \\
\hline 20. & & ENDO & & \\
\hline 21. & & & & \\
\hline 22. & & ENDO & & \\
\hline
\end{tabular}

Lines 2, 3, and 4 are produced in the assembler output five times.
Lines \(9,10,11,21\), and the lines produced by the operation of the DO directives on lines 12 and 15 are produced in the assembler output 10 times.

Within each of the 10 sets of code produced by the DO directive on line 8 , lines 13,14 , and the lines produced by the operation of the DO directive on line 15 are generated in the assembler output three times.

Within each of the 30 sets of code produced by the DO directives on lines 8 and 12, lines 16, 17, and 18 are generated in the assembler output five times.

\subsection*{27.4.3. Conditional Assembly Control Counter (ACTR)}

You use the ACTR statement to limit the number of AGO, AIF, GOTO, AGOB, AIFB, and GO statements that may be processed by the assembler either within a macro or within the source program.

The ACTR statement source code format is:
\begin{tabular}{c|l|l} 
LABEL & \(\triangle\) OPERATION \(\triangle\) & \\
\hline unused & ACTR & SETA expression
\end{tabular}

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^{23}-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 the counter is zero prior to decrementing, 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 that initiated the nest. If the source code is being processed (outside a macro definition), an END directed 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_{10}\).

\subsection*{27.5. 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 \((\mathrm{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. The format of an attribute reference is as follows:
\begin{tabular}{c|l|l} 
LABEL & DOPERATION \(\triangle\) & \\
\hline [symbol] & \begin{tabular}{l} 
conditional \\
assembly \\
operation \\
code
\end{tabular} & \(\left.\left\{\begin{array}{l}T \\
\mathrm{~L} \\
\mathrm{~S} \\
\mathbf{l} \\
\mathrm{~K} \\
\mathrm{~N}\end{array}\right\}, \begin{array}{l}\text { symbol } \\
\text { \&symbol }\end{array}\right\}\)
\end{tabular}

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. (See 4.4.5. for a discussion of the use of lengthattribute references in program source code.)

The origin of an attribute value is always either a symbol or a parameter. Table 27-3 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 it is referenced. 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. Any one of the valid attributes can be acquired for a symbol or \&SYSLIST. A SET symbol and the system variable symbols listed in Table 27-3 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 by using the symbol in the attribute reference. Macro instruction operands cannot be referenced from program source code so a symbolic parameter or a \&SYSLIST cannot be part of an attribute reference in program source code. However, a SET symbol and the system variable symbols listed in Table 27-3 can be used in an attribute reference in program source code.

Table 27-3. Valid Attribute Reference Applications
\begin{tabular}{|c|c|c|c|c|c|c|c|}
\hline \multicolumn{6}{|c|}{Attribute} & \multirow{2}{*}{Refarence} & \multirow{2}{*}{Location} \\
\hline T & L & s & 1 & к & N & & \\
\hline \(\checkmark\) & \(\checkmark\) & \(\sqrt{ }\) & \(\checkmark\) & & & Symbol & \multirow{5}{*}{Macro source code} \\
\hline \(\sqrt{ }\) & & & & \(\checkmark\) & & Set symbol & \\
\hline \(\checkmark\) & \(\checkmark\) & \(\sqrt{ }\) & \(\checkmark\) & \(\checkmark\) & \(\checkmark\) & Symbolic parameter & \\
\hline \(\checkmark\) & \(\checkmark\) & \(\checkmark\) & \(\checkmark\) & \(\checkmark\) & \(\checkmark\) & \&SYSLIST & \\
\hline \(\checkmark\) & & & & \(\checkmark\) & & \&SYSNDX, \&SYSPARM, \&SYSJDATE, \&SYSECT and \&SYSTIME & \\
\hline \(\checkmark\) & \(\checkmark\) & \(\checkmark\) & \(\checkmark\) & & & Symbol & \multirow{3}{*}{Program source code} \\
\hline \(\checkmark\) & & & & \(\checkmark\) & & SET symbol & \\
\hline \(\checkmark\) & & & & \(\checkmark\) & & \&SYSPARM, \&SYSDATE, \&SYSJDATE, and \&SYSTIME & \\
\hline
\end{tabular}
\(\sqrt{ }=\) 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 least 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 regard to the call operand attributes, you must abide by the same criteria in addition to the following. 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 cannot use a length attribute if the type attribute is \(\mathrm{J}, \mathrm{M}, \mathrm{N}, \mathrm{O}, \mathrm{T}\), or U (see 27.5.1.).

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. If a SET symbol appears in the operand entry of a macro instruction, attribute information is not provided and the operand may not be accessed as a sublist.

\subsection*{27.5.1. 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 27-4 summarizes the type attributes and the circumstances under which they are produced.

Table 27-4. Type Attributes of Symbols (Part 1 of 2)
\begin{tabular}{|c|l|l|l|}
\hline Type & \multicolumn{1}{|c|}{\begin{tabular}{c} 
Symbol \\
Definition
\end{tabular}} & \begin{tabular}{c} 
Length \\
Specification
\end{tabular} & Alignment \\
\hline A & \begin{tabular}{l} 
Type A address \\
constant
\end{tabular} & Implied & Full-word \\
\hline B & \begin{tabular}{l} 
Binary constant \\
C
\end{tabular} & \begin{tabular}{l} 
Character \\
constant \\
explicit
\end{tabular} & Not applicable \\
\hline D & \begin{tabular}{l} 
Double-word \\
floating-point \\
constant
\end{tabular} & \begin{tabular}{l} 
Implied or \\
explicit
\end{tabular} & Not applicable \\
\hline E & \begin{tabular}{l} 
Full-word \\
floating-point \\
constant
\end{tabular} & \begin{tabular}{l} 
Full-word \\
fixed-point \\
constant
\end{tabular} & Implied \\
\hline F & Fixed-point & Fouble-word \\
\hline G & \begin{tabular}{l} 
Fonstant
\end{tabular} & Not applicable \\
\hline
\end{tabular}

Table 27-4. Type Attributes of Symbols (Part 2 of 2)
\begin{tabular}{|c|c|c|c|}
\hline Type & Symbol Definition & Length Specification & Alignment \\
\hline H & Half-word fixed-point constant & Implied & Half-word \\
\hline 1 & Machine instruction & Implied & Half-word \\
\hline J & Control section name & Not applicable & Double-word \\
\hline K & Floating-point constant & Explicit & Not applicable \\
\hline M & Macro instruction & Not applicable & Not applicable \\
\hline \(N\) (1) & Self-defining term & Not applicable & Not applicable \\
\hline 0 (1) & Omitted operand & Not applicable & Not applicable \\
\hline P & Packed decimal constant & Implied or explicit & Not applicable \\
\hline \(R\) & Unaligned address constant (A, S, V, or Y) & Explicit & Not applicable \\
\hline S & Type S address constant & Implied & Half-word \\
\hline T & External symbol & Not applicable & Not applicable \\
\hline U (2) & Type not available & Not applicable & Not applicable \\
\hline V & Type \(V\) address constant & Implied & Full-word \\
\hline W & CCW statement & Implied & Double-word \\
\hline \(x\) & Hexadecimal constant & Explicit or implied & Not applicable \\
\hline \(Y\) & Type \(Y\) address constant & Implied & Half-word \\
\hline 2 & Zoned decimal constant & Explicit or implied & Not applicable \\
\hline
\end{tabular}
(1) This type attribute is produced only for macro instruction operands.
(2) 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.

\subsection*{27.5.2. 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.
\begin{tabular}{ccc} 
LABEL & \(\triangle O P R E R A T I O N \triangle\) & OPERAND \\
10 & 16 &
\end{tabular}
\begin{tabular}{|c|c|c|}
\hline & - & \\
\hline & - & \\
\hline & DC & \\
\hline DATA & OC & FLフ'7E+9 \\
\hline
\end{tabular}

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). These could be written in conditional statements such as:


An L' cannot be generated directly by a macro/proc; it can be done indirectly as follows:
\begin{tabular}{lll} 
& LCLC & \(\varepsilon A, \varepsilon B\) \\
\(\varepsilon A\) & SETC & \(' Z '\) \\
\(\varepsilon B\) & SETC & \(' L \prime \prime \prime\) \\
& MVC & \(\varepsilon A .(\varepsilon B \varepsilon A), X\)
\end{tabular}

After generation this would result in:
MVC Z(L'Z), X

\subsection*{27.5.3. Scale Attributes}

You can reference scale attributes of variable symbols by coding an \(S^{\prime}\) followed by the desired symbol. Scaling attributes are available only for labels of statements defining fixedpoint constants. This restricts them to H, F, D, E, P, type Z, type K, and type G constants in the \(O S / 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 \(\triangle^{\prime}-19.788^{\prime}\) would be 8 , since it is specifying 8 bits for the fractional part of the number. For decimal type constants the scaling attribute is the number of decimal digits to the right of the decimal point.

The following examples illustrate typical usages of scale attributes:
\begin{tabular}{|c|c|c|}
\hline LABEL & \multicolumn{2}{|l|}{\(\triangle\) OPERATION \(\triangle\)} \\
\hline 1 & 10 & 16 \\
\hline & - & \\
\hline & - & \\
\hline & \(\dot{A} \mid F\) & (S'\&S(1) EQ S'\&S(2)).SI \\
\hline & - & \\
\hline & - & \\
\hline & - & \\
\hline \&SCALE & SET & \(S^{\prime} \varepsilon P(1)\) \\
\hline & - & \\
\hline & - & \\
\hline & DO & \\
\hline & DO & S'EVARY 6 \\
\hline
\end{tabular}

\subsection*{27.5.4. Integer Attributes}

An integer attribute can be written with an l' 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 a fixed-point or floating-point constant ( \(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\left(I^{\prime}=8^{*} L-S^{\prime}-1\right)\). For floating point, you obtain the integer attribute, multiplying by 2 , and subtracting the scaling attribute \(I^{\prime}=2^{*}\left(L^{\prime}-1\right)-S^{\prime}\). Typical fixed-point constants and their computed integer attributes are:
\begin{tabular}{lll} 
& \(\cdot\) & \\
& \(\cdot\) & \\
HLFWRD & DC & HS4'97.65' \\
FULLWRD & DC & FS12'47.8959'
\end{tabular}

A half-word fixed-point constant \((H)\) would have a length attribute of \(2\left(L^{\prime}=2\right)\) and a scale attribute specified as \(4\left(S^{\prime}=4\right)\). Therefore, the integer attribute would be \((8 \times 2)-8-1=7\). A full-word fixed-point constant would have a length of \(4\left(L^{\prime}=4\right)\) and a scale attribute specified here as \(12\left(S^{\prime}=12\right)\). The integer attribute in this case would be \((8 \times 4)-12-1=19\).

Some floating-point constants and their computed integer attributes are:


Since \(E\) is a floating-point full word, its length attribute is \(4\left(L^{\prime}=4\right)\). The scale attribute is specified to be \(3\left(S^{\prime}=3\right)\). Thus, the integer attribute is \(2(4-1)-3=3\). When we have a floating-point double-word constant (D), its length attribute is \(8\left(L^{\prime}=8\right)\). The scale attribute is shown to be 6 . We can then compute the integer attribute 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.

\subsection*{27.5.5. 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. Examples using count attribute references in statements are:


\subsection*{27.5.6. 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 omission of operands in the sublist. This attribute is available in SETA, DO, SETB, or AIF directives.

Examples of number attribute usage are:


If an operand is not a sublist, the number attribute is 1 . If an operand is omitted, its value is 0 .

The following is an example showing all the attribute references available, along with the related constants and local directives that a SET directive requires in a program environment.
\begin{tabular}{|c|c|c|c|}
\hline & PROC & \multicolumn{2}{|l|}{EPARAM, 1} \\
\hline DATTR & \multicolumn{3}{|l|}{NAME} \\
\hline \multicolumn{4}{|l|}{二DISPLAY ATTRIBUTES OF MACRO INSTRUCTION OPERAND} \\
\hline \multirow[t]{3}{*}{.* THIS} & \multicolumn{3}{|l|}{COMMENT IS NOT GENERATED} \\
\hline & LCLA & \multicolumn{2}{|l|}{\(\varepsilon S Q, \varepsilon \mid 0, \varepsilon K Q, \varepsilon N Q, \varepsilon L Q\)} \\
\hline & LCLC & \multicolumn{2}{|l|}{\&TQ} \\
\hline \(\varepsilon 10\) & SETA & \multicolumn{2}{|l|}{I'EPARAM (1)} \\
\hline \(\varepsilon S Q\) & SETA & \multicolumn{2}{|l|}{S'EPARAM(1)} \\
\hline EKQ & SETA & \multicolumn{2}{|l|}{K'EPARAM (1)} \\
\hline ENQ & SETA & \multicolumn{2}{|l|}{N'EPARAM (1)} \\
\hline \(\varepsilon L Q\) & SETA & \multicolumn{2}{|l|}{L'EPARAM (l)} \\
\hline \multirow[t]{9}{*}{\(\varepsilon T Q\)} & SETC & \multicolumn{2}{|l|}{T'EPARAM (1)} \\
\hline & DC & \(C^{\prime}\) 'EPARAM (1)' & THIS IS THE OPERAND \\
\hline & DC & \(Y(\varepsilon L Q)\) & LENGTH ATTRIBUTE OF PARAM \\
\hline & DC & \(Y(\varepsilon K Q)\) & COUNT ATTRIBUTE OF PARAM \\
\hline & DC & \(Y(\varepsilon \mid 0)\) & INTEGER ATTRIBUTE OF PARAM \\
\hline & DC & \(Y(\varepsilon S Q)\) & SCALE ATTRIBUTE OF PARAM \\
\hline & DC & \(Y\) (ENQ) & NUMBER OF OPERANDS IN SUBLIST \\
\hline & DC & \(C^{\prime} \varepsilon T Q^{\prime}\) & TYPE ATTRIBUTE OF PARAM \\
\hline & END & & \\
\hline
\end{tabular}

\section*{PART 6. ASSEMBLY LISTING}

\section*{28. Organization of Listing}

\subsection*{28.1. HEADER LINES}

The assembly listing produced by the OS/3 assembler consists of five sections, each with its own headings. The five sections are:
- PREFACE

Lists of options and assembler identification.
- CODEDIT

Object code and source code entries
- EXTERNAL SYMBOL DICTIONARY LISTING
- CROSS-REFERENCE LISTING
- DIAGNOSTIC LISTING

\subsection*{28.2. PREFACE}

The first section or preface section identifies the assembler variant (if any), its version and update number, and the time and date of the assembly. The formats:

UNIVAC OS/3 ASSEMBLER
DATE yy/mm/dd TIME - hh.mm
The preface also lists parameters indicating the assembler options selected in the job control stream, if any.

\subsection*{28.3. CODEDIT}

In this section, source coding is printed beside the object code generated for it. The first header line in this section contains the operand field used in the TITLE statement. The header, except for the page number, will be blank. The headings in the second line are shown in Table 28-1.

Table 28-1. CODEDIT Listing Content
\begin{tabular}{|l|l|}
\hline Second Heading Line & \multicolumn{1}{c|}{ Field Contents } \\
\hline LOC & \begin{tabular}{l} 
Assembler address of the object code in hexadecimal.
\end{tabular} \\
\hline OBJECT CODE & \begin{tabular}{l} 
Contains the object code produced from the source statement. \\
This field is left-justified and is in hexadecimal. Machine \\
instructions are printed in the format: \\
mmmmmmmmminmm
\end{tabular} \\
Constants are printed in the form: \\
C- - C
\end{tabular}

Although a sequence heading does not print in the assembly listing, you are permitted to have a sequence field that does print. Lines of code generated by a macro or proc call line retain any sequence number they had when they were originally coded. That is, the original sequence number is printed in the assembly listing on the same line as the generated statement.

\subsection*{28.4. EXTERNAL SYMBOL DICTIONARY LISTING}

This section is optional; you can request its omission at assembly time. Entries are generated in the external symbol dictionary listing for named and unnamed section definitions (defined by CSECT statement), entry points (defined by an ENTRY statement), external symbols (EXTRN statement and type \(V\) constants), and common sections (COM statement). A description of the information which is contained in this section is given in Table 28-2.

Table 28-2. External Symbol Dictionary (ESD) Listing Content
\begin{tabular}{|c|c|}
\hline Second Heading Line & Field Comments \\
\hline SYMBOL & Contains the symbol that caused the ESD entry to be generated. \\
\hline TYPE & \begin{tabular}{l}
Defines the type of entry: \\
CSECT Section definition (CSECT or START) \\
ENTRY Symbol appeared in operand field of ENTRY statement. \\
EXTRN External reference (symbol appeared in EXTRN operand field or defined as type V address constant) \\
COM Common control section definition
\end{tabular} \\
\hline ESID & Two-digit external symbol identification number (in hexadecimal) of item. \\
\hline ADDRESS & Contains the address of the symbol in hexadecimal for ENTRY ESDS, the starting address of the control section for CSECT and COM items, and blank for EXTRN ESDS. \\
\hline LENGTH & Contains a hexadecimal value which is the assembled length (in bytes) of control on common section. Blank for ENTRY and EXTRN ESD items. \\
\hline
\end{tabular}

\subsection*{28.5. CROSS-REFERENCING LISTING}

This section is optional, you can request its omission at assembly time. When this section is included, each symbol in the object program is listed in alphanumeric sequence with the statement number of the statement defining it, and the statement numbers of all references to it. Also included in the data for the symbol are the length attribute of the symbol and the value assigned to the symbol in the assembly.

The first heading line of every page contains the following:

\section*{CROSS REFERENCE}

The information on each page of the cross-reference listing appears in one column on the left half of the page. If more space is needed, the assembler prints a second column of cross-reference data on the right half of the page. Each column has a heading line followed by one or more data lines. The formats of the column heading and data lines are given in Table 28-3.

Table 28-3. Cross-Reference Content
\begin{tabular}{|l|l|}
\hline Second Heading Line & \multicolumn{1}{c|}{ Field Comments } \\
\hline SYMBOL & Symbol to which cross-reference data pertains. \\
\hline LENGTH & \begin{tabular}{l} 
Length (in decimal) of data associated with symbol (i.e., implied \\
length of symbol).
\end{tabular} \\
\hline VALUE & \begin{tabular}{l} 
Hexadecimal value of symbol.
\end{tabular} \\
\hline DEFN & \begin{tabular}{l} 
Statement number of statement in which symbol is defined. \\
Mumbers of \\
reference) \\
May a stantain from 0 to 5 entries of the form nnnn number, and \(\Delta \Delta\) represents two blanks. Each entry \\
represents a statement number of a line in which the symbol \\
is referenced. Succeeding lines will be used as necessary to \\
list all the references or duplicate definitions. Leading zeros \\
are suppressed.
\end{tabular} \\
\hline \begin{tabular}{l} 
Printing of the symbol cross-reference listing is in double-column \\
format. Continuation occurs from the bottom of the left-hand \\
column to the top of the right-hand column and from the bottom of \\
the right-hand column to the top of the left-hand column on the \\
next page. The last page of the listing may contain any part of a \\
partial page.
\end{tabular} \\
\hline
\end{tabular}

\subsection*{28.6. DIAGNOSTIC LISTING}

Statements containing errors are flagged and appear in the diagnostic listing. The diagnostic listing follows the assembly listing and contains a detailed accounting of any errors that 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 (Appendix F) 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, those of its statements that contain errors are listed and flagged immediately after the END statement. To obtain a listing of the macro statement containing the diagnostic error, you must use the LST=DGB 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.

The first heading line contains the following:

\section*{DIAGNOSTICS}

The format of the second heading line and the data line contents are given in Table 28-4.

Table 28-4. Diagnostic Listing Content
\begin{tabular}{|l|l|}
\hline Second Heading Line & \multicolumn{1}{c|}{ Field Contents } \\
\hline STMT & \begin{tabular}{l} 
May contain from 1 to 10 entries of the form nnnn \(\triangle \triangle\), where \\
nnnn represents a statement number of a line in which the error \\
occurred and \(\triangle \triangle\) represents two leading blanks. Leading zeros \\
are suppressed.
\end{tabular} \\
\hline ERROR CODE & Error code of the error in form annn. \\
\hline MESSAGE & An actual error message giving details about the error. \\
\hline
\end{tabular}

After the listing of the diagnostics, the assembler prints the total number of statements that were in error as follows:
nnnn STATEMENTS FLAGGED IN THE ASSEMBLY - \(y y / m m / d d h h . s s\)
The final error statement message is also displayed on the console upon completion of the assembly. This lets you know immediately if there are any diagnostic errors in your source program.

\subsection*{28.7. EXAMPLE OF ASSEMBLY LISTING}

Section 29 contains a sample assembly listing.

\section*{PART 7. PROGRAMMING TECHNIQUES}
\(\bullet\)

\section*{29. Job Control Procedures}

\subsection*{29.1. HOW TO RUN A JOB}

To assemble, link edit, and execute your program, you must tell the computer what you want it to do for you. You assign peripheral devices and then request other programs and routines for use in your program. Job control is your means of communicating with the computer. Job control procedures are designed to enable you to get your program into the computer in the most efficient way. These procedures are similar to macro definitions. They generate a series of job control statements by using one calling line of code. This section includes the job control procedures you need to assemble your program into an object module, to link-edit your program into a load module, and finally, to execute it. There are job control procedures available for many other functions but they are not discussed here. The minimum number of job control statements needed to run your program are provided. For additional information on job control, refer to the current version of the job control user guide, UP-8065.

When using a multisectioned program or unfamiliar instructions, assemble the program and correct any syntax, addressability, or other errors. Then, add the job control cards needed to link-edit and execute, and resubmit the job. Assemble your program and store the object module in a private library for execution at another time or store the object module and link it to another object module for combined execution. The current version of the system service programs user guide, UP-8062, contains information about link-editing and how to create and access files of stored information.

\subsection*{29.2. INTRODUCING THE SOURCE DECK}

To assemble your source program into an object code module, you need to surround your source code deck with job control statements. The job control statements needed to introduce the source deck are discussed in 29.2.1 and 29.2.2.

\subsection*{29.2.1. JOB Control Statement}

The first job control statement in your deck is the JOB control statement, which assigns a unique name to your job. It is the only required parameter, as you can see from the format. See the current version of the job control user guide, UP-8065, for an explanation of the other parameters.
\[
\begin{aligned}
& / /[\text { symbol }] \text { JOB jobname }\left[\left\{\begin{array}{c}
P \\
H \\
\mathbf{N}
\end{array}\right\}\right]\left[\text {,min] [,max] }\left[\cdot\left\{\begin{array}{c}
\text { tasks } \\
\mathbf{1}
\end{array}\right\}\right]\right. \text { [,max-time] [,(op-list-1,...,op-list-n)] } \\
& {\left[\text { ,acct-no] [,nXm] } \left[\left\{\begin{array}{l}
\left.\begin{array}{l}
\text { NOACT } \\
\text { NOLOG } \\
\text { NONE } \\
\text { BOTH }
\end{array}\right\}
\end{array}\right\}\left[\left\{\begin{array}{l}
\text { NOHDR } \\
\text { HDR }
\end{array}\right\}\right]\right.\right.}
\end{aligned}
\]

The jobname can have up to eight alphanumeric characters. The name you specify on the JOB control statement has no bearing on the name you assign on the START card (see 17.5) within your assembly program. The jobname parameter distinguishes one job from another. Use a unique name, since only one job can be scheduled for processing by the operating system under a name. (If two jobs have the same name, the second job would replace the first job.)

\subsection*{29.2.2. OPTION Job Control Statement}

Following the JOB control statement, you can include an OPTION job control statement to cause a program dump at the end of your assembly listing. There are three kinds of dumps you can request, depending on the parameter you choose:


These dumps are explained in the current version of the system service programs user guide, UP-8062. When a program terminates normally, the OPTION job control statement alone does not produce a dump. You must have a corresponding DUMP or SNAP card within your assembly program. DUMP and SNAP are supervisor macros created to dump portions or all of your assembly program. DUMP and SNAP are explained in the current version of the supervisor user guide, UP-8075.

If your program terminates abnormally and you've included an OPTION job control statement, you'll get a dump following the assembly listing.

If an OPTION job control statement is not present in the control stream, the DUMP macro instruction acts as an EOJ macro instruction. The OPTION job control statement must also be in the job step in which you want the dump to occur. For example, if you assemble, linkedit, and execute your load module, and you want the dump to occur when you execute your load module, you place the OPTION job control statement in the job step that executes your load module, not in the one that assembles or link-edits.

\subsection*{29.3. ASSEMBLE; ASSEMBLE AND LINK-EDIT; OR ASSEMBLE, LINK-EDIT, AND EXECUTE}

You can assemble, link-edit, and execute your program in steps or do it all at once. Each of these functions requires a different job control procedure (jproc) call statement. You can use any one of these jproc call statements, depending on what you want to do:
- ASM - Assembles your source deck.
- ASML - Assembles and then link-edits.
- ASMLG - Assembles, link-edits, and then executes the generated load module.

\subsection*{29.3.1. Assemble (ASM)}

When you assemble, you create and name (either directly or indirectly) an object module. Errors incurred during assembly are flagged and listed on the printout in the diagnostics following the assembly listing. Once you have an error-free assembly, you are ready to execute. To execute, you must add the job control statements to your deck (and ASM jproc call statement) that link-edit and execute your program. Or, you can replace the ASM jproc call statement with the jproc call statement to assemble and link-edit (ASML) or assemble, link-edit, and execute (ASMLG). The latter approach is suggested. It is more practical to let the prewritten job control procedures do the work rather than having to keypunch the additional cards. If you do not use ASML or ASMLG jprocs, you will have to consult the current version of job control user guide, UP-8065 for the additional cards needed.

Remember, the object module you produce during assembly is not saved (unless you say so with a parameter). After the assembly is complete, the object module is removed from the temporary job \(\$\) YSRUN file. If you want to save it for later use, you must store it in a system library, or a library of your own. The librarian portion of the current version of system service programs user guide, UP-8062, describes system and user libraries.

\subsection*{29.3.1.1. ASM Jproc Call Statement}

The format of the jproc call statement that generates only an assembly follows. Except for the OUT parameter, the format also applies to the ASML and ASMLG statements discussed in 29.3.2 and 29.3.3.
\(/ /\left[\right.\) symbol \(\triangle A S M \Delta \quad\left[\right.\) PRNTR \(\left.=\left\{\begin{array}{l}\text { lun }[, \text { dest }] \\ N[, \text { dest }] \\ 20[\text { dest }]\end{array}\right\}\right]\)

\(\left[\right.\) OUT \(\left.=\left\{\begin{array}{l}\begin{array}{l}\text { (vol-ser-no,label) } \\ \text { (RES,label) } \\ \text { (RUN,label) } \\ \text { (*, label) } \\ \text { (N) } \\ \text { (RUN,SYSRUM }\end{array}\end{array}\right\}\right]\)


\(\left[, L S T=\left\{\begin{array}{l}\text { option } \\ \text { (opt-1, }, \ldots, \text { opt-n })\end{array}\right\}\right]\)
\(\left[. \operatorname{SCR} 1=\left\{\begin{array}{c}\text { vol-ser-no } \\ \text { REs }\end{array}\right\}\right]\)
\(\left[\right.\).SCR2 \(\left.=\left\{\begin{array}{c}\text { vol-ser-no } \\ \text { RUW }\end{array}\right\}\right]\)


The symbol field of the ASM jproc call statement is an optional field. There is no space between the // and the symbol. Normally, your input (the source module) is in the form of punched cards. But, possibly, you may have stored the source module in a library. The symbol field supplies the name of the source module (one to eight alphanumeric characters). (The symbol field is only needed when you use the IN parameter.)

If no name is specified on the START directive, ASMOBJ is assigned. You can have only one unnamed assembly (the default, ASMOBJ) within a job unless all other assemblies are continuations of the first. For example, if performing two individual assemblies within the same job, proceed as follows:
\begin{tabular}{lll} 
LABEL & \(\triangle O P E R A T I O N \Delta\) & OPERAND \\
1 & 10 & 16
\end{tabular}
// JOB COMSTOR
// ASM
/\$
PROGA START \(\emptyset\)
-
\(\cdot\)
END
\(1:\)
// ASM
/\$
PROGB START \(\emptyset\)
-
-
END
/*
/ \(\varepsilon\)
// FIN
In this example, the first assembly is named PROGA, and the second is named PROGB. The jobname is COMSTOR. When you use the IN keyword parameter, you must also use the symbol field. (This is discussed when the IN keyword parameter is discussed.)

The keyword parameters of the ASM jproc call statement are optional. The shaded areas indicate the default values generated if you do not use the parameter. You can use statement continuation to contain all the parameters you want to specify. Following are examples of correct and incorrect coding:

Correct Example:
\begin{tabular}{ll}
\(/ /\) JOB ASSEMBLE & \\
\(/ / P R O G N M\) ASM & PRNTR=21, IN=(DSC1,U\$SRC), \\
\(/ / 1\) & \(O U T=(D S C 2, U \$ O B J)\), \\
\(/ / 2\) & \(L I N=(D S C 1, U \$ M A C 1, D S C 2, U \$ M A C 2)\) \\
\(/ \varepsilon\) &
\end{tabular}

Incorrect Example:
You cannot break a parameter specification. The keyword and its value must be on the same card. You can not code the IN parameter as follows:
\begin{tabular}{lll} 
LABEL & \(\triangle O P E R A T I O N \triangle\) & OPERAND \\
1 & 10 & 16
\end{tabular}
// JOB ASSEMBLE //PROGNM ASM
\[
\begin{aligned}
& \text { PRNTR=21, IM=DSC1: } \\
& \text { USSRC) }
\end{aligned}
\]

This coding would cause an error. To continue on another card you need a nonblank character (we used X) in 72, and, in the next card, a // in columns 1 and 2 followed by a number in column 3 as shown in the correct example. The column 3 numbers must be in ascending order in the deck, in the range of 1 through 9 , or they can all have the same number. If there are two continuation cards, as shown in the correct example, the first card cannot be \(/ / 2\) and the second card \(/ / 1\). But it could be \(/ / 2\) and \(/ / 2\).

The parameter definitions are as follows:
PRNTR=
Allocates a specific printer for the assembly listing.
N
If you specify \(\mathbf{N}\), the device assignment set for the printer is not generated by the jproc. Instead, the device assignment set for the printer is manually inserted by the user in the control stream (prior to the placement of the jproc call). This allows for the creation of specific load code and vertical format buffers (the LCB and VFB job control statements) by the user.

For example:
```

//DVC 26 // VFB LENGTH=66,DENSITY=6
// LFD PRNTR
// ASM PRNTR=N

```

NOTE:
When this parameter is used, the file name for the device assignment set for the printer must be PRNTR.

Iun
If you want a logical unit number other than 20 , you must specify the logical unit number associated with the printer you select.

20
If you specify 20 as the logical unit number, you will get the next available printer. This parameter is optional because 20 is the default value.
dest
If you spool the printed output and want to send it to a device at a remote site, you use this parameter to specify the device's 1 - to 6 -alphanumericcharacter destination identifier as it is defined by remote batch processing.

\section*{\(\mathrm{IN}=\)}

You only use the \(\mathbb{I N}\) keyword parameter when the source program is not on cards. If you have stored your unassembled program on a disk, you use the \(\mathbb{I N}\) parameter to retrieve it for assembly. When using this parameter, you must have the name of the source program you are retrieving in the symbol field of the ASM jproc call statement. The options are:

\section*{(vol-ser-no,label)}

Specifies the volume serial number and the file identifier where the source module is located. For example, it could be on a disk whose volume serial number is DSC1. The disk is assigned that number. On the disk, the source program, named PROGNM, is stored in a library called US\$SRC. To assemble the source program, specify the IN keyword parameter to define the input. (This parameter must be used when making source corrections via the SKI, REC, and SEQ statements; see F.2.)

LABEL \(\triangle O P E R A T I O N \triangle\) OPERAND
\(\begin{array}{lll}1 & 10 & 16\end{array}\)
// JOB ASSEMB2A
//PROGNM ASM \(\quad I N=(D S C 1, U \$ S R C)\)
(RES)
Indicates you want to retrieve a source program from the system resident device (SYSRES) in the source library file ( \(\$\) YSSRC).
(RES,label)
Indicates you want to retrieve your source program from SYSRES. But it is not in SY\$SRC; it is in a file identified by the label.
(RUN,label)
Indicates you want to retrieve a source program from the volume containing the job's run library file ( \(\$ Y \$ R U N\) ). The label is the file identifier.
(*,label)
Indicates you want to retrieve a source program from a cataloged file. The label is the file identifier, which is all that is necessary to identify the file to the system.

\section*{OUT=}

You use this parameter to store assembled object modules in a library other than the job's \$Y\$RUN file to save your assembly. Remember that the ASM jproc only stores your program until the job is complete. To permanently save an object module, you must put it somewhere with the OUT parameter. This also generates a PARAM OUT job control statement. The options are:
(vol-ser-no,label)
Specifies the volume serial number and file identifier where you want to store the object module. It is assumed that this file has been already allocated. If it is not, you have to supply a device assignment set to allocate this file.
(RES,label)
Indicates that you put your object module on SYSRES, but you didn't use the reserved \(\$ Y \$ S R C\) file; you named your own file. The label is the file identifier.
(RUN,label)
Indicates you put the object module on the volume containing the job's \(\$ Y \$ R U N\) file in the file identified by label.
(*,label)
Indicates you want to store the object module in a cataloged file. The label is the file identifier, which is all that is necessary to identify the file to the system.
(N)

Indicates you do not want the object module stored in your own file or retrieved from \(\$ \mathbf{Y} \$ \mathrm{RUN}\).

LIN=
You can use the macro library file (\$Y\$MAC) to store the macro definitions or you can use a nonsystem library. The LIN keyword parameter identifies the library you want searched. If you do not specify this parameter, \$Y\$MAC is searched. The options are:
(vol-ser-no-1,label-1[,vol-ser-no-2,label-2])
Provides the volume serial numbers and file identifiers. You can specify up to two volumes and files where macros are stored. \$Y\$MAC is searched if the desired macros are not found elsewhere.
(RES,label-1[,RES,label-2])
Specifies two library files to be searched for macros; both are files on SYSRES.
(RUN,label-1[,RUN,label-2])
Specifies two library files to be searched for macros; both are files on the volume containing the job's run library file ( \(\$ Y \$ R U N\) ).
(*, label-1[,*, label-2])
Specifies two library files to be searched for macros; use this format when the files are cataloged, so you need only specify the file identifiers.
(N)

Indicates that no macros should be retrieved.
COPY=
Identifies library files containing stored source programs that are to be copied into another source program. You can specify two volumes and two files. If you do not specify this parameter, \(\$ Y \$ S R C\) is searched for any source programs named in an assembler COPY directive. This parameter works with the COPY directive, which names the source programs you want to copy into your program. The options are:
(vol-ser-no-1,label-1[,vol-ser-no-2,label-2])
Provides the volume serial numbers and file identifiers. You can specify up to two volumes and files where source programs are stored.
(RES,label-1[,RES,label-2])
Specifies two library files containing stored source programs; both files are on SYSRES.

\section*{(RUN,label-1[,RUN,label-2])}

Specifies two library files containing stored source programs; both files are on the volume containing the job's run library file (\$Y\$RUN).
(*, label-1[,*,label-2])
Specifies two library files containing stored source programs; you use this format when the files are cataloged, so you need only specify the file identifiers.
(N)

Specifies that no source programs should be copied.
LT \(=\)
Alters the normal assembly listing and generates a PARAM LST job control statement. If you do not use this keyword parameter, the assembly listing contains a source, object, cross-reference, and diagnostic listing. You can specify LST options in either of two ways:

The options are:
option
Specifies a single option.
(opt-1...,opt-n)
Specifies more than one option. The parentheses are required.

N
Specifies that no assembly listing is produced.
NC
Specifies that no cross-reference listing is produced.
ND
Specifies that no diagnostic listing is produced.
NR
Specifies that the cross-reference listing is to contain only symbols that each have at least one reference. The NC option, if specified with NR, always overrides it.

\section*{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.
- All lines flagged (regardless of their order of 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.

SCR1 \(=\) and SCR2 \(=\)
The assembler needs two scratch work areas to perform its calculations. Normally, the SYSRES device is used for one file and the volume containing the job \(\$\) Y\$RUN file for the other file. This is what is generated by default. But, you can use a different volume if desired.

SCR1=vol-ser-no and SCR2=vol-ser-no
Specify the volume serial numbers of the work files. The default for SCR1 is SYSRES, and the default for SCR2 is the volume containing the job's \$Y\$RUN file.

\section*{ALTLOD=}

Identifies the file from which the assembler will be loaded.

\section*{(vol-ser-no,label)}

Provides the volume serial number of the pack from which the assembler will be loaded and the name of the file that contains the assembler.
(RES,label)
Indicates that the assembler is to be loaded from the file identified by label on SYSRES.
(RUN,label)
Indicates that the assembler is to be loaded from the file identified by label on the volume containing the job's run library file ( \(\$ Y \$ R U N\) ).
(*,label)
Indicates that the assembler is to be loaded from a cataloged file specified by label.
(RES,SY\$LOD)
Indicates that SYSRES is the volume from which the assembler will be loaded and that \(\$ Y \$ L O D\) is the file that contains the assembler. This is the default.

\subsection*{29.3.2. Assemble and Link-Edit (ASML)}

When you assemble and link-edit your program, you create and name an object module and a load module. The load module is temporarily stored in the job's \(\$ Y \$ R U N\) file. The job is not executed. You only assemble and link-edit without executing if you are referencing something in your program that is defined in another program. For example, you may have external references (EXTRN), data management routines (DTFPR), supervisor routines (DUMP), etc. At link-edit time, cross-referencing between object modules is completed and loose ends are tied together. If you can link-edit without error, you are one step closer to completing the job.

The load module is saved temporarily in the job \(\$ Y \$ R U N\) file, thus enabling all separate object modules to communicate while the job is being run. Once the link edit is complete, the load module is removed from \(\$ Y \$ R U N\). The load module can be stored permanently as discussed in the current version of the linkage editor portion of the system service programs user guide, UP-8062. It is important to realize you are using more main storage, for a longer period of time, when you assembly and link than when you just assemble. When you use the ASML jproc call statement, you cannot use the OUT parameter to define an output library and save the generated object module.

\subsection*{29.3.2.1. ASML Jproc Call Statement}

The format of the ASML jproc call statement generates an assembly and then automatically link-edits the object module. The options shown are described in 29.3.1.1. Again note that the OUT option is not included.
[symbol] \(\triangle A S M L \triangle\)


This jproc call statement is useful when you are still testing your program, since it lets you see the output of your job without reserving a file for it. Once the job is executing properly, you can allocate a file and store the load module by using the linkage editor. This jproc call statement is also useful for infrequently run jobs.

The functions and use of the linkage editor are explained in the current version of the system service programs user guide, UP-8062. There also is a jproc for executing the linkage editor, just as there is one for executing the assembler. This jproc call allows you to do more with the generated load module than either the ASML or ASMLG jprocs, such as storing the load module in a library. (This does not mean you cannot store your load module when you use either the ASML or ASMLG jproc call statements; it only means you cannot do it by the jproc call itself). You also can use the LINKOP linkage editor control statement but this involves more coding, and the jprocs are designed to reduce coding. The jproc call statement for the linkage editor is included in the current version of the job control user guide, UP-8065.

\subsection*{29.3.3. Assemble, Link-Edit, and Execute (ASMLG)}

When you use the ASMLG jproc call statement, you create and name both an object module and a load module, temporarily store it in the job \(\$ Y \$ R U N\) file, and then execute it. The load module is stored in the job \$Y\$RUN until execution of the job is completed. You cannot use the ASMLG jproc call when the system has the shared data management feature because job control must first scan the load modules in \$Y\$LOD for this feature. The GO option associated with the ASMLG jproc call cannot be used. If you use the ASM jproc call with a separate LINK jproc call or the ASML jproc call and want to execute the program using the shared data management feature, you must provide a separate EXEC statement.

\subsection*{29.3.3.1. ASMLG Jproc Call Statement}

The format of the ASMLG jproc call statement generates an assembly, creates a load \(\downarrow\) module, and executes your program. The options shown in this format are described in 29.3.1.1. Notice, however, that the default value of the ALTLOD parameter is RUN, \(\$\) Y\$RUN when using the ASMLG jproc call statement. The OUT keyword parameter does not apply to the ASMLG jproc call statement; only to the ASM jproc call statement.
[symbol] \(\triangle A S M L G \triangle\left[P R N T R=\left\{\begin{array}{c}\text { lun [,dest] } \\ \mathbf{N}[, \text { dest }] \\ 20,[\text { dest }]\end{array}\right]\right.\)

\(\left[\right.\), LST \(\left.=\left\{\begin{array}{l}\text { \{option } \\ \text { loption }-1, \ldots, \text { opt-n })\end{array}\right\}\right]\)


NOTE:
Calling the ASML or ASMLG jproc more than once in a single job may create unpredictable results. As called by either of these jprocs, the linkage editor includes all object modules currently residing in the job \(\$ Y \$ R U N\) file, even those modules generated by ASML or ASMLG jprocs called earlier in the job. In this way, you may accidentally include object code that has no place in your intended program. To avoid this problem you should:
1. call only one ASML or ASMLG jproc per job; or
2. assemble individual object modules separately using the ASM jproc, then link the modules together with one of the linkage editor jprocs described in the current version of the system service programs and job control user guides; these linkage editor jprocs give you more control over the generated load module.

\subsection*{29.4. START-OF-DATA JOB CONTROL STATEMENT (/\$)}

A start-of-data job control statement must precede the first card of the source program or any macros being submitted with the source program.


\subsection*{29.5. FOLLOWING THE SOURCE DECK}

Following the END card in the source deck, you need job control cards to tell the computer that you have completed part or all of your job.

\subsection*{29.5.1. End-of-Data Job Control Statement (/*)}

An end-of-data job control statement follows the END directive of the source program.
\begin{tabular}{lll} 
// JOB MYPROG & \\
// ASMLG & \\
/\$ & & \\
PROGNM & START & \(\emptyset\) \\
& \(\cdot\) & \\
& & \\
& & \\
\hline & &
\end{tabular}

\subsection*{29.5.2. End-of-Job Control Statement (/\&)}

An end-of-job control statement terminates the job which was started by the last JOB control statement. It indicates that all job steps have been completed.
```

LABEL \triangleOPERATION\triangle OPERAND
1 10 16
// JOB COMSTOR
// ASM
/\$
PROGA START \emptyset
•
.
END
/*
// ASM
/\$
PROGB START \emptyset
.
•
END
/*
/\varepsilon
// FIN

```

\subsection*{29.5.3. Terminate-the-Card-Reader Job Control Statement (//FIN)}

A terminate-the-card-reader job control statement ends a card reader operation. This statement follows the end-of-job control statement as shown in the coding form in 29.5.2.

\subsection*{29.5.4. Setting the UPSI Byte}

If any errors are detected in your program while it is being assembled, the assembler sets the User Program Switch Indicator (UPSI) byte according to OS/3 system standards to indicate the type of errors that occurred.
\begin{tabular}{lll} 
UPSI Byte & \(\frac{\text { Setting }}{1\left(X^{\prime} 80^{\prime}\right)}\) & \begin{tabular}{l} 
Meaning \\
Catastrophic errors were detected in the source program \\
that prevented completion of the requested function. An \\
object module was not generated.
\end{tabular} \\
Bit 1 & 0 & \begin{tabular}{l} 
No catastrophic errors were detected.
\end{tabular} \\
& 0 & \begin{tabular}{l} 
Serious errors were detected that may have affected (but \\
not prevented) the completion of the requested function. \\
An object module was generated but the results could be \\
unpredictable.
\end{tabular} \\
& No serious errors were detected.
\end{tabular}

Bit \(21\left(X^{\prime} 20^{\prime}\right)\)
\(0 \quad\) No diagnostic errors were detected.

\section*{NOTE:}

In the event of a program check, the UPSI byte setting \(X^{\prime} 80^{\prime}\), in combination with a supervisor macro (STXIT), provides continuation to the next job step rather than complete termination of the job stream. The job step that resulted in the program check is cancelled and a dump is produced. For further details about STXIT, see the supervisor user guide, UP-8075 (current version).

\subsection*{29.6. SUMMARY OF JOB CONTROL PROCEDURE}

The following card deck and sample printouts demonstrate the difference in an output listing when the same source program is assembled; assembled and link-edited; and assembled, link-edited, and executed in three separate steps.

\subsection*{29.6.1. Assembly}

The following source desk requests an assembly:


The listing produced by the assembly source deck is as follows. The headings are explained in Section 28.
```

UNIVAC SYSTEM OS/3 ASSEMBLER

| PROG | CSECT | 01 | 000000 | 000104 |
| :--- | :--- | :--- | :--- | :--- |
| OUT | ENTRY | 01 | 000040 |  |
| OUTC | ENTRY | 01 | 000072 |  |
| OPSCOMO | EXTRN | 02 |  |  |



### 29.6.2. Assembly and Link-Edit

The following source deck requests an assembly and link-edit:


The listing produced by this deck is as follows:


| 00004000000000000000000 | 33* | OC | 7F ${ }^{\circ}{ }^{\text {c }}$ |
| :---: | :---: | :---: | :---: |
| O0305C D6E4E 340404040 | 34* | DC | CLT'OUT' DCSNME |
| 000063 - 0 | 35* | DC | CL1* |
| 0000640000 | $36+$ | EC | $\mathrm{H}^{\prime} \mathrm{O}^{\prime}$ DPSMFLG |
| 0000660000 | 37. | DC | $H^{\prime \prime} \mathrm{C}^{\text {c }}$ DPSPUB |
|  | 38 |  | * PRAD Not specified. Standari line acyance set to 1. |
|  | 39 |  | *, PECORD FORMAT KEYWORD NOT SPECIFIED. SET TO FIXUNB. |
| 00006800000000 | $40+$ | DC | AZOA DPSPOY |
| 0000600000 | 41* | DC | $\mathrm{H}^{\circ} \mathrm{O}^{\circ}$ DPSPLA |
| OCOO6E 04FJ | 4 く* | DC | xL2'04FO' DPSDTF |
| 00007 FO | 430 | OC | CLI'O* |
| 00007100 | 44. | DC | XL1'O日* DPSREOS |
| 000072 | 4.*OUTC | EQu | * error flag label |
|  | 46* | ENTRY | OUTC |
| 0000720000 | 47. | OC | H'S' DPSEFG |
| 00007400000000 | 48. | CC | Aztus Conca opsiocs |
|  | 49* | EXTRN | DPSC OMO |
|  | 50 |  | *, No ERROR ROUTINE. ERRORS RETURN TNLIME. |



[^2]| S YMB OL | LENGTH | value | LINE |  |  |  |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| BEGIN | 00002 | 000000 | 00002 | 0076 |  |  |  |  |
| BRANCH | 00004 | 000002 | 00004 | 0007 | 0007 | 0014 |  |  |
| BuF | 00016 | DODOEC | 00075 | 0014 | 0053 | 0054 |  |  |
| DPSC OMO |  |  |  | 0048 |  |  |  |  |
| OUT | 00001 | 000040 | 00031 | 0012 | 0017 | 0023 | 0032 | 0077 |
| OUTC | 00001 | 000072 | 00045 | 0046 |  |  |  |  |
| PRog | 00001 | 000000 | 00001 |  |  |  |  |  |
| save | 00072 | 000040 | 00073 | 0069 | 0070 |  |  |  |

no Statement s flagged in this assenbl
-75/38/27 19.55-
*DEFINITIONS DICTIONARY*

| SYAB OL. | TYPE. | Phase. | ADORESS. | SYMBOL. | TYPE. | Phase. | ADURESS. | SYMBOL. | JYPE. | PHASE. | MDORESS. |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| DPSC OMO | ENTRY | ROOT | 03000000 | DPSCOM1 | EMTRY | ROOT | 20003030 | OPSCOM2 | Entay | 8901 | 10000000 |
| DPSCOM3 | ENTRY | ROOT | 10300000 | OPSCOM4 | ENTRY | R001 | 00000000 | DPSCOMS | ENTRY | ROOT | -0092005 |
| OPSCOMS | ENTRY | ROOt | 00000000 | OPSCOM7 | ENTRY | ROOI 1 | 0000000 | KESALP | CNTRY | ABS | 39000584 |
| KESRES | ENTRY | ABS | 00000584 | OUT | ENTRY | R00 1 | 303004F0 | OUTC | ENTRY | ROOT | 39009522 |
| prsioe | csect | ROOT | 00000000 | PROG | CSECt | H001 | 00300480 |  |  |  |  |

* ${ }^{\text {PPHASE StRUCTURE** HEX BYTES REPRESENTED BY EACH DASH - E }}$

I JJo 5B4*


```
UNIVAC SYSTEA OS/3 LINKAGL EDITOR
```

DATE-75/08/27 IIME-19.55
CONTROL STREAM ENCOUNTIRED ANO PROCESSLE AS FOLLOUS-
*GEneratedo luath
PROG *RUN LIBE MODULE*
DPSCOMJ *AUTO-INCLUDED*

The definitions dictionary, phase structure, and allocation map are explained in the current version of the system service programs user guide, UP-8062.

### 29.6.3. Assembly, Link-Edit, and Execution

The following source deck requests an assembly, link-edit, and execution:


The listing produced by this service deck is the same as the assembler and link listing, but it includes the results of the execution. This program moved letters and printed out the field containing $A B C D E F G H$.

## 30．Example Macro Definitions

This section gives examples of both PROCs and MACROs．The explanation of these examples places the primary emphasis on the macro source code instead of on the resulting inline expansion source code．Descriptions of the macro definitions resolve around variable parameter replacement and variable inline expansion code caused by conditional assembly statements．Each description is accompanied by the macro source code and an example call with the inline expansion code．

## 30．1．SMALR／LARGR PROC（POSITIONAL PARAMETER 0）

The following example PROC selects either the smallest or largest of three positional parameters submitted in the call instruction．Two different mnemonics are provided for indicating whether the smallest or largest value is selected．The call SMALR is used for smallest value selection and the call LARGR is used for largest value selection．This PROC is a good example of using positional parameter 0 ．

PROC Source Code：

| EDMY | PROC | C 1.4 | ： |
| :---: | :---: | :---: | :---: |
| SHALR | NAME | ENH |  |
| LARGR | NAME | ENL |  |
|  | AIF | （N＇E\＃NE MI．ERR | Test for 4 parameters．Branch to print error message if untrue． |
| EDMY | ZAP |  | Select first value． |
|  | $C P$ | ど111，\＆（3） | Compare to next value． |
|  | \＆\＃ 0 ） | ＊＊10 | BNH or BNL or |
|  | 2 AP |  | Select next value． |
|  | $C P$ | と事11）\＆¢（4） | Compare to next value． |
|  | c）（0） | ＊+10 | BNH or BNL or |
|  | ZAP |  | Select next value |
|  | MEXIT |  |  |
| ．ERR | MNOTE | ＇IMPROPER PARAMETERS－－NO | GENERATION＇ |
|  | END |  |  |

Inline Expansion Code（smallest value）：

```
SMALR SELECT,VAL1,VAL2,VAL3
ZAP SELECT,VALJ
CP SELECT,VALZ
BNH **10
ZAP SELECT,VALZ
CP SELECT,VAL3
BNH *+10
ZAP SELECT,VALS
```

Inline Expansion Code (largest value):

```
LARGR SELECT,VALI,VALZ,VAL3
ZAP SELECT,VALI
CP SELECT,VAL2
BNL **10
ZAP SELECT,VALZ
CP SELECT,VALS
BNL **10
zap SELECT,VAL3
```

Operand 2 of the PROC statement indicates there are four positional parameters that can be passed from the call instruction, and $\& \#$ is the symbolic parameter that references the positional parameters. This PROC requires all four positional parameters from the PROC. Otherwise, no inline expansion takes place and the message coded in the MNOTE is printed.

The AIF conditional assembly statement tests to see whether the four parameters are present. Whether the smallest or largest value is selected from the call instruction is dependent upon generation of the BNH or BNL instruction in the inline expansion code. This is controlled by the call-names SMALR or LARGR used in the two NAME statements. SMALR implements BNH for positional parameter 0 and LARGR implements BNL.

The two model statements referencing positional parameter $0(\& \#(0))$ are the instructions that determine smallest or largest value selection. The inline expansion code shows that the SMALR call instruction generates BNH in place of \&\#(0) and the LARGR call instruction generates BNL. The SMALR call instruction generates BNH in place of \&\#( 0 ) and the LARGR call instruction generates BNL.

Positional parameter 1 of the call instructions indicates an area to receive the selected value. It is referenced in the model statements ( $\& \#(1))$ in operand 1 of the add instructions and compare instructions. Positional parameters 2 through 4 of the call instructions are the values to be selected. The model statements that perform the calculations for finding the smallest or highest value have references to positional parameters 2 through 4 ( $\& \#(2)$ through \&\#(4)).

The MEXIT statement ends PROC processing at this point in the PROC, so the message isn't printed. The MNOTE is printed only if there aren't four positional parameters in the call instruction.

### 30.2. SMALL6/LARGE6 PROC (DO LOOP)

The following example PROC selects either the smallest or largest of the positional parameters in the call instruction, just like the SMALR/LARGR PROC. This PROC broadens the usage range by allowing the caller to specify from 3 to 100 values instead of limiting the caller to only 3 as did the SMALR/LARGR example PROC. There are two call mnemonics provided: the SMALL6 is used for small value selection and the LARGE6 is used for large value selection. The two mnemonics are provided via positional parameter 0 . The SMALL6/LARGE6 PROC shows a design using DO loops to provide variable inline expansion code. The DO range is determined by the number of values in the call instruction; the more values in the call, the more lines of source code generated.

PROC Source Code:

| CDMY | PROC | EP, 100 |  |
| :---: | :---: | :---: | :---: |
| SMALL6 | name | ENH |  |
| LARGE6 | Name | BNL |  |
|  | DO | N'\&P>2 |  |
| GOMY | ZAP | \&P111, \& P 21 |  |
| ECT | DO | N: \&P-2 |  |
|  | CP | \&P(1), \&P |  |
|  | CT*21) | Inner DO loop. The instructions CP, BNH/BNL, |  |
|  | \& P(0) | * +10 (1) | and ZAP will be generated the number of positional |
|  | ZAP | \&P(1):\&P(ECT+2) | parameters in the call instruction minus two. |
|  | ENOO ENOO |  |  |
|  | DO | N'EPく3 |  |
|  | PNOTE | *NOGEN* *MINIMUM OF | three parameters required* |
|  | $\begin{aligned} & \text { ENOO } \\ & \text { END } \end{aligned}$ |  |  |

Inline Expansion Code (smallest value):


Inline Expansion Code (largest value):

| 2AP | SELECT, VALI |  |
| :---: | :---: | :---: |
|  |  |  |
| CP | SELECTival2 ${ }^{\text {a }}$ (10 1 |  |
| ZAP | SELECT,VAL2 |  |
| CP | SELECT,VAL3) |  |
| BNL | * +10 O 2 |  |
| ZAP | SELECT, VAL3 | Outer DO processed because number of parameters |
| CP | SELECT,VAL4 ${ }^{\text {a }}$ | are more than 2 (DO N\&P>2). |
| $\begin{aligned} & B N L \\ & Z^{\prime} A P \end{aligned}$ | SELECT,VAL4 |  |
| CP | SELECT,VAL5 ${ }^{\text {a }}$ |  |
| BNL | *+10 $\}^{4}$ |  |
| ZAP | SELECT,VALS |  |

Operand 2 of the PROC statement indicates that the user can code up to 100 parameters in the call instruction while the symbolic parameter is \&P. Two mnemonic codes can be used to call this PROC, as coded in the label field of the two NAME statements. Each is used to implement different BAL instruction codes via positional parameter $O$ ( $\& P(O)$ ). In this PROC, positional parameter $O$ is referenced only one time, while in SMALR/LARGR it was referenced twice. This is because the inner DO loop generates the required number BNH/BNL instructions to process the number of values coded in the call instruction. Of course, the inner DO is never processed unless the outer DO is.

In order for the outer DO to be processed，there must be more than two positional parameters in the call（ $D O N^{\prime} \& P>2$ ）．If there are two parameters or less，a zero is generated in the outer DO operand and the DO with the PNOTE is generated．

A 1 is generated in the operand field of the PNOTE DO because there are less then three parameters（DO N＇\＆PL3），and the message in the PNOTE is generated．The call instruction for the SMALL6／LARGE6 example PROC must have a minimum of 3 positional parameters and can have a maximum of 100 ．This gives a range of 1 to 98 values to be tested for the highest or lowest value．If you compare this with the SMALR／LARGR example PROC，you can see that the SMALL6／LARGE6 PROC provides much more than SMALR／LARGR and has only one more line of code．

## 30．3．BLANK MACRO（VARIABLE INLINE EXPANSION CODE）

The following example MACRO blanks（ $\mathrm{X}^{\prime} 00^{\prime}$ ）the content of a specified number of bytes． There are only two positional parameters that can be submitted with the BLANK call instruction，and one is optional．Positional parameter 1 indicates the starting address of the area to be cleared，and positional parameter 2 specifies the number of bytes to be cleared．If the number of bytes in the area is less than 257，parameter 2 is optional．The BLANK MACRO is an example of variable inline expansion code．There are three basic sets of code that can be generated from this MACRO．Positional parameter 2 is used to determine which set is generated．

MACRO Source Code：

|  | MaCRO |  |  |
| :---: | :---: | :---: | :---: |
| comy | blank | を\＃1，¢\＃2 |  |
|  | lCla | ELA1 |  |
|  | DO | （N＇ESYSLIST＞2）＋＊（N＇ESYSLISTく」） | Error check |
|  | mnote | 7．＇Improper parameters－no geniration． |  |
|  | MEXIt |  |  |
|  | ENDO |  |  |
|  | DO | N＇ESYSLIST＝1 |  |
|  | ${ }^{1} \mathrm{IF}$ | IL＇E\＃1 GT 256J．A」 | Code generated if positional parameter 2 is omitted |
| Comy | $\times \mathrm{C}$ |  |  |
|  | MEXIT |  |  |
| ． 11 | MNOTE MEXIT | 6．${ }^{\circ}$ LENGTH OF EH1＞256－PARAM： 2 MUST BE USED． |  |
|  | ENDO |  |  |
|  | AIF | （T＇E\＃2 NE－N•J．A2 |  |
| Elal | SEta | \＆\＃2 |  |
| EDMy | L | 15，＝A（E\＃1） |  |
|  | 00 | ع\＃21256 |  |
|  | $\times \mathrm{C}$ | 01256，15），01151 | Code generated for more than 256 bytes |
|  | LA | 15，256115，01 |  |
| ［（1）］ | SETA | ELA1－256 |  |
|  | ENOO |  |  |
|  | －0 | ع1a1＞0 |  |
|  | $\begin{aligned} & \times \mathbf{C} \\ & \text { ENDO } \end{aligned}$ | O1ELA1，151，01151 | Code generated for less than $\mathbf{2 5 6}$ bytes |
|  | MEXIT |  |  |
| ． 42 | MNOTE | 8，＇Parameter 2 not nuyeric． |  |

Inline Expansion Code:

| blank | PRTBF. 80 |  |
| :---: | :---: | :---: |
| 1 | 15, =A (PRTBF) | These two instructions were generated from the last DO because |
| X $C$ | O(80,15),0115) | positional parameter 2 is less than 256. |

The prototype statement establishes the call mnemonics as BLANK and indicates there can be two positional parameters in the call that are referenced in the body as \&\#1 and \&\#2. The LCLA declares \&LA1 as an arithmetic set symbol. Set symbols must be declared following the heading and preceding any other model statements.

The rest of the body of this MACRO is sectioned by four DO statements. The first DO is an error exit. If either or both expressions on each side of the OR ( ++ ) operator are true, than no code is generated and the MNOTE message is printed. That is, the numeric attribute of the parameter list ( $N^{\prime} \& S Y S L I S T$ ) is anything other than 1 or 2 , then the blank MACRO will not work.

The second DO is processed only if there is one parameter in the parameter list ( $N$ '\&SYSLIST=1). And if the area indicated by positional parameter 1 is greater than 256, the AIF statement will shunt the generation of the XC instruction (the blanking operation) and print the MNOTE message. If the numeric attribute of the parameter list is 2 , then the second DO loop is not processed and the AIF after this DO is processed. This AIF tests positional parameter $2(\& \# 2)$ for a self-defining term; if it isn't, no code is generated and the MNOTE is printed.

The \&LA1 set symbol is set to the value of positional parameter 2, which is the number of bytes to be cleared. Register 15 is loaded with the address of area (\&\#1). The next DO loop is processed once for every multiple of 256 bytes indicated in positional parameter 2 (DO $\& \# 2 / 256$ ). If positional parameter 2 is less than 256 , the next DO is processed and the last one is not.

There are three sets of codes that can be generated from the BLANK example MACRO. One set is generated if positional parameter 2 is omitted; another if positional parameter 2 is more than 256; and another if positional parameter 2 is less than 256.

## PART 8. APPENDIXES

## Appendix A. Sample Program

The following list illustrates the steps taken to create, code, and execute a simple assembler program. The sample problem is designed to calculate the effect of a $\$ 5.00 \mathrm{a}$ week bonus on an employee's yearly, weekly, and hourly pay.

- Flowchart

The flowchart provides a graphic representation of the logic steps used to solve the problem.


## Source Code

Source code is created to implement the logic flow set forth in the flowchart. In the following list, comments have been included to explain what each source statement does.

| STMT | SYMBOL | OPERATION CODE | STATEMENT OPERANDS | COMMENTS |
| :---: | :---: | :---: | :---: | :---: |
| 1 |  | title | 'FIRST SAMPLE PROGRAM' | Provides the assembler listing with a heading. |
| 2 | PROGRAM 1 | START | 0 | Provides a starting point for the program. |
| 3 | BEGIN | BALR | R6,0 | Assigns a base address to the register. |
| 4 |  | USING | *,R6 | Assigns a base register to the program. |
| 5 |  | ZAP | WORKAREA,BONUS | Enter bonus rate into work area. |
| 6 |  | MP | WORKAREA, WEEKS | Multiply bonus rate by 52 weeks. |
| 7 |  | AP | WORKAREA, YEARRATE | Add yearly rate to total bonus. |
| 8 |  | MVC | YEARPAY,WORKAREA+2 | Move calculated total to yearly pay area. |
| 9 |  | DP | WORKAREA, WEEKS | Divide total pay by 52 weeks. |
| 10 |  | MVC | WEEKPAY,WORKAREA+1 | Move results to weekly pay area. |
| 11 |  | ZAP | WORKAREA, WEEKPAY | Move weekly pay into work area. |
| 12 |  | DP | WORKAREA,HOURS | Divide by 40 hours week. |
| 13 |  | MVC | HOURPAY,WORKAREA+2 | Move results to hourly pay area. |
| 14 |  | MVC | OUTPUT(23),EMPLOYEE | Completed record moved to output area. |
| 15 |  | EOJ |  | End of job. |
| 16 | WORKAREA | DS | CL6 | Reserve 6 bytes of storage, contents unknown. |
| 17 | BONUS | DC | PL2'500' | Place value 5.00 in two bytes of storage. |
| 18 | HOURS | DC | PL2'40' | Place value 40 in two bytes of storage. |
| 19 | WEEKS | DC | PL2'52' | Place vatue 52 in two bytes of storage. |
| 20 | YEARRATE | DC | PL4'1300000' | Place value 13000.00 in four bytes of storage. |
| 21 | OUTPUT | DC | 23C | Produces 23 bytes of blanks only. |
| 22 | EMPLOYEE | DS | OCL23 | Symbol "EMPLOYEE" represents next 23 bytes. |
| 23 | NAME | DC | CL9'REBEW R D' | Produces nine bytes containing "REBEWRD". |
| 24 | WORKNO | DC | C'N4543' | Produces five bytes containing "N4543". |
| 25 | Yearpay | DC | PL4'0' | Produces four bytes of zeros. |
| 26 | WEEKPAY | DC | PL3'0' | Produces two bytes of zeros. |
| 27 | hourpay | DC | PL2'0' | Produces two bytes of zeros. |
| 28 | R6 | EQU | 6 | This instruction equates register 6 with R6. |
| 29 |  | END | BEGIN | this is the end of the program. |

## Job Control Procedure to Assemble

The following job control statements assemble the source code into an object code module.

```
Job Control Statements
// JOB ASSEMBLE
// ASM
/$
    - Assembler
    . source
    . code
/% Signifies the end of the source statements.
/\varepsilon Signifies the end of the job.
// FIN
```


## Comments

Assigns a unique name to the program.
Assembles the source code.
Signifies the start of the source statements.

Signifies the end of the source statements.
Signifies the end of the job.
Terminates card reader operation.

- Output Generated by Assembly

The program is now assembled and an assembly listing is generated. The assembly listing contains warning messages if any errors are detected in the source code.


FIRST SAMHLE PROGRAM

LOC. OBJECT CODE ADORI AJORZ LINE SOURCE STATEMENT


| SYMB OL | LENSTH | value | JEFN |  |  |  |  |  | SYMEOL | LENGTH | value | OEFN |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| BEGIN | 00002 | 000000 | 30003 | 0031 |  |  |  |  |  |  |  |  |
| Bonus | 00002 | 000046 | 00019 | 0005 |  |  |  |  |  |  |  |  |
| EMPLOYEE | 00023 | 000067 | 20024 | 0014 |  |  |  |  |  |  |  |  |
| HOURPAY | 00002 | 000076 | 00029 | 0013 |  |  |  |  |  |  |  |  |
| MOURS | 00002 | 000048 | 50c20 | 0012 |  |  |  |  |  |  |  |  |
| WATE | 00009 | 000067 | 30025 |  |  |  |  |  |  |  |  |  |
| OUTPUT | 04001 | 000050 | 00023 | 0014 |  |  |  |  |  |  |  |  |
| PR OGRAM1 | 00001 | 000000 | 00002 |  |  |  |  |  |  |  |  |  |
| R6 | 30001 | 000006 | 00030 | 0003 | 0004 |  |  |  |  |  |  |  |
| MEEKPAY | 00003 | 000079 | 00028 | 0010 | 2011 |  |  |  |  |  |  |  |
| WEEKS | 00002 | 00004 4 | 00521 | 0006 | 30.9 |  |  |  |  |  |  |  |
| morkarea | 00006 | $0 \cup 0040$ | 00018 | 0035 | 0006 | $\bigcirc 007$ | gung | 0609 |  |  |  |  |
|  |  |  |  | 0010 | 0011 | 0012 | 0013 |  |  |  |  |  |
| WORKNO | 00005 | 000070 | 00026 |  |  |  |  |  |  |  |  |  |
| YEARPAY | 00004 | 000075 | 00027 | 0008 |  |  |  |  |  |  |  |  |
| Yearrate | 00004 | 000045 | 30022 | 0057 |  |  |  |  |  |  |  |  |

- Job Control Procedure to Assemble, Link-edit, and Execute

After the errors in the source code are corrected, the following job control statements are added to assemble the code, create a load module, and execute the program.

Job Control Statements
// JOB ASSEMBLE
// ASMLG
/\$

- Assembler
. source
. code
/
$/ \varepsilon$
// FIN

Comments
Assigns a unique name to the program.
Assembles, link-edits, and executes the program.
Signifies the start of the source statements.

Signifies the end of the source statements.
Signifies the end of the job.
Terminates card reader operation.

## Appendix B. Character Conversion Codes

Table B-1. ASCII (American Standard Code for Information Interchange) Character Codes

|  | 0 | 1 | 2 | 3 | 4 | 5 | 6 | 7 |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| 0 | NUL | DLE | SP | 0 | @ | P | 1 | $p$ |
| 1 | SOH | DC1 | ! (1) | 1 | A | O | a | q |
| 2 | STX | DC2 | " | 2 | B | R | b | $r$ |
| 3 | ETX | DC3 | \# | 3 | C | S | c | $s$ |
| 4 | EOT | DC4 | \$ | 4 | D | T | d | t |
| 5 | ENO | NAK | \% | 5 | E | U | e | $u$ |
| 6 | ACK | SYN | \& | 6 | F | $V$ | f | $\checkmark$ |
| 7 | BEL | ETB | , | 7 | G | W | 9 | w |
| 8 | BS | CAN | 1 | 8 | H | X | h | $\times$ |
| 9 | HT | EM | ) | 9 | 1 | $Y$ | 1 | V |
| A | LF | SUB | * | : | $J$ | Z | 1 | $z$ |
| B | VT | ESC | + | ; | K | 1 | k | 1 |
| C | FF | FS | , | $<$ | $L$ | $\backslash$ | I | 1 |
| D | $C R$ | GS | - | \# | M | ] | m | 1 |
| E | SO | RS | . | $>$ | $N$ | $\wedge$ (1) | n | $\sim$ |
| $F$ | SI | US | 1 | $?$ | $\bigcirc$ | - | 0 | DEL |
|  |  |  |  |  |  |  |  |  |

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 in the character set:

7 for $\wedge$
| for !
(3) Graphics available by use of the 0768-02 printer which prints a 94-character set (DEL is not a graphic)
(4) Ninety-four printable character set.
(2) Sixty-three printable character set.

Table B-2. EBCDIC (Extended Binary Coded Decimal Interchange Code) Character Codes

|  | 0 | 1 | 2 | 3 | 4 | 5 | 6 | 7 | 8 | 9 | A | B | c | D | E | F |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| 0 | NUL | DLE | DS(1) |  | SP | \& | - |  |  |  |  |  | (4) | $)^{(4)}$ | (4) | 0 |
| 1 | SOH | DC1 | $\operatorname{sos}{ }^{(1)}$ |  |  |  | 1 |  | ${ }_{a}$ (4) | i | ~4. |  | A | $J$ |  | 1 |
| 2 | STX | DC2 | FS ${ }^{(1)}$ | SYN |  |  |  |  | b | k | $s$ |  | B | K | S | 2 |
| 3 | ETX | DC3 |  |  |  |  |  |  | c | 1 | t |  | c | L | T | 3 |
| 4 |  | (6) |  |  |  |  |  |  | d | m | $\checkmark$ |  | D | M | $u$ | 4 |
| 5 | HT |  | LF |  |  |  |  |  | e | n | $v$ |  | E | $N$ | $v$ | 5 |
| 6 |  | BS | ETB |  |  |  |  |  | f | - | w |  | F | 0 | w | 6 |
| 7 | DEL |  | ESC | EOt |  |  |  |  | g | p | x |  | G | P | x | 7 |
| 8 |  | CAN |  |  |  |  |  |  | h | q | v |  | H | - | Y | 8 |
| 9 |  | EM |  |  |  |  |  | (4) | i | r | $z$ |  | 1 | R | $z$ | 9 |
| A |  |  |  |  | 1 | (5) | (3) |  |  |  |  |  |  |  |  |  |
| B | VT |  |  |  | . | \$ |  | \# |  |  |  |  |  |  |  |  |
| c | FF | $\text { Fs }{ }^{5}$ |  | DC4 | < | * | \% | @ |  |  |  |  |  |  |  |  |
| D | CR | GS | ENO | NAK | 1 | 1 | - |  |  |  |  |  |  |  |  |  |
| E | $50^{5}$ | $\mathrm{Rs}^{5}$ | ACK |  | + | ; | $>$ | $=$ |  |  |  |  |  |  |  |  |
| F | $\mathrm{si}^{5}$ | us | $\begin{array}{r} 5 \\ B E L \\ \hline \end{array}$ | SUB | $\text { (2) } 5$ | $7^{(2)}$ | ? | " |  |  |  |  |  |  |  |  |

NOTES:

Some graphic card code and hexadecimal assignments may differ depending on the device, language, application, and installation policy.

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 Institute X3.4-1968, they must not appear in external storage media, such as American National Standard Institute standard tapes. This presents no difficulty due to the nature of the EDIT instruction.
(2) The following optional graphics can be substituted in the character set:
$\wedge$ for 7
|for!
(3) For 63 -character printers, the following substitution is made:

1 for '
(4) The lowercase alphabet and indicated graphics are introduced by use of the 0768-02 printer, which prints a 94-character set.

The following substitutions are made for the UTS 400 handler:

| SPROT | for SO |
| :--- | :--- |
| EPROT | for SI |
| SB | for FS |
| EB | for GS |
| SOE | for RS |
| FCC | for US |
| MW | for BEL |
| ] | for ! |
| ! | for ] |

(6) DC4 for the UTS 400 handler.

Table B-3. Punched Card, ASCII, and EBCDIC Codes (Part 1 of 5)

| Character | Printed Symbol | Card <br> Punches | ASCII |  | EBCDIC |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  | Hexadecimal | Decimal | Hexadecimal | Decimal |
| Letters |  |  |  |  |  |  |
| A | A | 12-1 | 41 | 65 | C1 | 193 |
| B | B | 12-2 | 42 | 66 | C2 | 194 |
| C | C | 12-3 | 43 | 67 | C3 | 195 |
| D | D | 12-4 | 44 | 68 | C4 | 196 |
| E | E | 12-5 | 45 | 69 | C5 | 197 |
| F | F | 12-6 | 46 | 70 | C6 | 198 |
| G | G | 12-7 | 47 | 71 | C7 | 199 |
| H | H | 12-8 | 48 | 72 | C8 | 200 |
| 1 | 1 | 12-9 | 49 | 73 | C9 | 201 |
| J | J | 11-1 | 4A | 74 | D1 | 209 |
| $K$ | K | 11-2 | 4B | 75 | D2 | 210 |
| L | L | 11-3 | 4C | 76 | D3 | 211 |
| M | M | 11-4 | 4D | 77 | D4 | 212 |
| $N$ | $N$ | 11-5 | 4E | 78 | D5 | 213 |
| 0 | 0 | 11-6 | 4F | 79 | D6 | 214 |
| P | P | 11-7 | 50 | 80 | D7 | 215 |
| 0 | Q | 11-8 | 51 | 81 | D8 | 216 |
| R | R | 11-9 | 52 | 82 | D9 | 217 |
| S | S | 0-2 | 53 | 83 | E2 | 226 |
| T | T | $0-3$ | 54 | 84 | E3 | 227 |
| U | U | 0-4 | 55 | 85 | E4 | 228 |
| V | V | 0-5 | 56 | 86 | E5 | 229 |
| W | W | 0-6 | 57 | 87 | E6 | 230 |
| X | $x$ | 0-7 | 58 | 88 | E7 | 231 |
| $Y$ | Y | 0-8 | 59 | 89 | E8 | 232 |
| $z$ | Z | 0-9 | 5A | 90 | E9 | 233 |
| a | a | 12-0-1 | 61 | 97 | 81 | 129 |
| $b$ | b | 12-0-2 | 62 | 98 | 82 | 130 |
| c | c | 12-0-3 | 63 | 99 | 83 | 131 |

Table B-3. Punched Card, ASCII, and EBCDIC Codes (Part 2 of 5)

| Character | Printed <br> Symbol | Card Punches | ASCII |  | EBCDIC |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  | Hexadecimal | Decimal | Hexadecimal | Decimal |
| d | d | 12-0-4 | 64 | 100 | 84 | 132 |
| e | e | 12-0-5 | 65 | 101 | 85 | 133 |
| $f$ | $f$ | 12-0-6 | 66 | 102 | 86 | 134 |
| g | 9 | 12-0-7 | 67 | 103 | 87 | 135 |
| h | h | 12-0-8 | 68 | 104 | 88 | 136 |
| i | i | 12-0-9 | 69 | 105 | 89 | 137 |
| j | j | 12-11-1 | 6 A | 106 | 91 | 145 |
| k | k | 12-11-2 | 6 B | 107 | 92 | 146 |
| 1 | 1 | 12-11-3 | 6C | 108 | 93 | 147 |
| m | m | 12-11-4 | 6D | 109 | 94 | 148 |
| $n$ | n | 12-11-5 | 6 E | 110 | 95 | 149 |
| 0 | $\bigcirc$ | 12-11-6 | 6 F | 111 | 96 | 150 |
| $p$ | $p$ | 12-11-7 | 70 | 112 | 97 | 151 |
| q | q | 12-11-8 | 71 | 113 | 98 | 152 |
| $r$ | 「 | 12-11-9 | 72 | 114 | 99 | 153 |
| $s$ | s | 11-0-2 | 73 | 115 | A2 | 162 |
| t | t | 11-0-3 | 74 | 116 | A3 | 163 |
| u | $u$ | 11-0-4 | 75 | 117 | A4 | 164 |
| $v$ | $v$ | 11-0-5 | 76 | 118 | A5 | 165 |
| w | $w$ | 11-0-6 | 77 | 119 | A6 | 166 |
| $\times$ | x | 11-0-7 | 78 | 120 | A7 | 167 |
| $v$ | V | 11-0-8 | 79 | 121 | A8 | 168 |
| $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 |

Table B-3. Punched Card, ASCII, and EBCDIC Codes (Part 3 of 5)

| Character | Printed <br> Symbol | Card Punches | ASCII |  | EBCDIC |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  | 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 |  |  |  |  |  |  |
| 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 | 78 | 123 |
| Dollar sign | \$ | 11-8-3 | 24 | 36 | $5 B$ | 91 |
| Percent sign | \% | 0-8-4 | 25 | 37 | 6 C | 108 |
| Ampersand | \& | 12 | 26 | 38 | 50 | 80 |
| Apostrophe, acute accent | , | 8-5 | 27 | 39 | 70 | 125 |
| Opening parenthesis | 1 | 12-8-5 | 28 | 40 | 4D | 77 |
| Closing parenthesis | ) | 11-8-5 | 29 | 41 | 50 | 93 |
| Asterisk | * | 11-8-4 | 2A | 42 | 5 C | 92 |
| Plus sign | + | 12-8-6 | 2 B | 43 | 4E | 78 |
| Comma, cedilla | , | 0-8-3 | 2 C | 44 | 6B | 107 |
| Minus sign, hyphen | - | 11 | 2 D | 45 | 60 | 96 |
| Period, decimal point |  | 12-8-3 | 2E | 46 | 48 | 75 |
| Slash, virgule, solidus | 1 | 0-1 | 2F | 47 | 61 | 97 |
| Colon | : | 8-2 | 3A | 58 | 7A | 122 |
| Semicolon | ; | 11-8-6 | 3B | 59 | 5 E | 94 |
| Less than | $<$ | 12-8-4 | 3 C | 60 | 4 C | 76 |
| Equal sign | = | 8-6 | 3D | 61 | 7 E | 126 |
| Greater than | > | 0-8-6 | 3E | 62 | 6 E | 110 |
| Question mark | ? | $0-8-7$ | 3F | 63 | $6 F$ | 111 |
| Commercial at symbol | @ | 8-4 | 40 | 64 | 7 C | 124 |
| Opening bracket | [ | 12-8-2 | 5B | 91 | 4A | 74 |
| Closing bracket | 1 | 11-8-2 | 50 | 93 | 5A | 90 |
| Reverse slash | 1 | 0-8-2 | 5 C | 92 | EO | 224 |
| Circumflex | $\wedge$ | 11-8-7 | 5 E | 94 | 5F | 95 |

Table B-3. Punched Card, ASCII, and EBCDIC Codes (Part 4 of 5)

| Character | Printed Symbol | Card Punches | ASCl! |  | EBCDIC |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  | 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 | CO | 192 |
| Closing brace | \} | 11-0 | 7D | 125 | DO | 208 |
| Vertical line | $1$ | 12-11 | 7 C | 124 | 6A | 106 |
| Overline, tilde | $\sim$ | 11-0-1 | 7E | 126 | A1 | 161 |


| Character | Card Punches | ASCII |  | EBCDIC |  |
| :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | Hexadecimal | Decimal | Hexadecimal | Decimal |
| Nonprintable Characters |  |  |  |  |  |
| ACK (Acknowledge) | 0-9-8-6 | 06 | 6 | 2E | 46 |
| BEL (Bell) | 0-9-8-7 | 07 | 7 | 2 F | 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 | OD | 13 | OD | 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 | 3 C | 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 | OC | 12 | oc | 12 |
| FS (File separator) | 11-9-8-4 | 1C | 28 | 1 C | 28 |

Table B-3. Punched Card, ASCII, and EBCDIC Codes (Part 5 of 5)

| Character | Card Punches | ASCII |  | EBCDIC |  |
| :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | Hexadecimal | Decimal | Hexadecimal | Decimal |
| FS (Field separator) | 0-9-2 | 82 | 130 | 22 | 34 |
| GS (Group separator) | 11-9-8-5 | 1D | 29 | 10 | 29 |
| HT (Horizontal tabulation) | 12-9-5 | 09 | 9 | 05 | 5 |
| LF (Line feed) | 0-9-5 | OA | 10 | 25 | 37 |
| NAK (Negative acknowledge) | 9-8-5 | 15 | 21 | 3 D | 61 |
| NUL (Null) | 12-0-9-8-1 | 00 | 0 | 00 | 0 |
| RS (Record separator) | 11-9-8-6 | 1E | 30 | 1 E | 30 |
| SI (Shift in) | 12-9-8-7 | OF | 15 | OF | 15 |
| SO (Shift out) | 12-9-8-6 | OE | 14 | OE | 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 | OB | 11 | OB | 11 |

## Appendix C. Math Tables

## C.1. HEXADECIMAL-DECIMAL INTEGER CONVERSION

The following table provides for conversion of hexadecimal and decimal numbers in the range:
$\frac{\text { Hexadecimal }}{000 \text { to FFF }} \quad \frac{\text { Decimal }}{0000 \text { to } 4095}$

In the table, the decimal value appears at the intersection of the row representing the most significant hexadecimal digits ( $16^{2}$ and $16^{1}$ ) and the column representing the least significant hexadecimal digit ( $16^{\circ}$ ).

Example:


For numbers outside the range of the table, add the following values to the table figures:

| Hexadecimal | Decimal | Hexadecimal | Decimal |
| :---: | :---: | :---: | :---: |
| 1000 | 4,096 | C000 | 49,152 |
| 2000 | 8,192 | D000 | 53,248 |
| 3000 | 12,288 | E000 | 57,344 |
| 4000 | 16,384 | F000 | 61,440 |
| 5000 | 20,480 | 10000 | 65,536 |
| 6000 | 24,576 | 20000 | 131,072 |
| 7000 | 28,672 | 30000 | 196,608 |
| 8000 | 32,768 | 40000 | 262,144 |
| 9000 | 36,864 | 50000 | 327,680 |
| A000 | 40,960 | 60000 | 393,216 |
| B000 | 45,056 | 70000 | 458,752 |

Example:

$$
B C 21_{16}=48,161_{10}
$$

Hexadecimal Decimal

## C21

3,105
$\frac{+\mathrm{B} 000}{+\mathrm{BC} 21} \quad \frac{+45,056}{48,161}$

HEXADECIMAL-DECIMAL INTEGER CONVERSION (Part 1 of 4)

|  | 0 | 1 | 2 | 3 | 4 | 5 | 6 | 7 | 8 | 9 | A | B | C | 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 | 0020 | 0021 | 0022 | 0023 | 0024 | 0025 | 0026 | 0027 | 0028 | 0029 | 0030 | 0031 |
| 02 | 0032 | 0033 | 0034 | 0035 | 0036 | 0037 | 0038 | 0039 | 0040 | 0041 | 0042 | 0043 | 0044 | 0045 | 0046 | 0047 |
| 03 | 0048 | 0049 | 0050 | 0051 | 0052 | 0053 | 0054 | 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 | 0089 | 0090 | 0091 | 0092 | 0093 | 0094 | 0095 |
| 06 | 0096 | 0097 | 0098 | 0099 | 0100 | 0101 | 0102 | 0103 | 0104 | 0105 | 0106 | 0107 | 0108 | 0109 | 0110 | 0111 |
| 07 | 0112 | 0113 | 0114 | 0115 | 0116 | 0117 | 0118 | 0119 | 0120 | 0121 | 0122 | 0123 | 0124 | 0125 | 0126 | 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 | 0160 | 0161 | 0162 | 0163 | 0164 | 0165 | 0166 | 0167 | 0168 | 0169 | 0170 | 0171 | 0172 | 0173 | 0174 | 0175 |
| OB | 0176 | 0177 | 0178 | 0179 | 0180 | 0181 | 0182 | 0183 | 0184 | 0185 | 0186 | 0187 | 0188 | 0189 | 0190 | 0191 |
| OC | 0192 | 0193 | 0194 | 0195 | 0196 | 0197 | 0198 | 0199 | 0200 | 0201 | 0202 | 0203 | 0204 | 0205 | 0206 | 0207 |
| 00 | 0208 | 0209 | 0210 | 0211 | 0212 | 0213 | 0214 | 0215 | 0216 | 0217 | 0218 | 0219 | 0220 | 0221 | 0222 | 0223 |
| OE | 0224 | 0225 | 0226 | 0227 | 0228 | 0229 | 0230 | 0231 | 0232 | 0233 | 0234 | 0235 | 0236 | 0237 | 0238 | 0239 |
| OF | 0240 | 0241 | 0242 | 0243 | 0244 | 0245 | 0246 | 0247 | 0248 | 0249 | 0250 | 0251 | 0252 | 0253 | 0254 | 0255 |
|  | 0 | 1 | 2 | 3 | 4 | 5 | 6 | 7 | 8 | 9 | A | B | C | 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 | 0277 | 0278 | 0279 | 0280 | 0281 | 0282 | 0283 | 0284 | 0285 | 0286 | 0287 |
| 12 | 0288 | 0289 | 0290 | 0291 | 0292 | 0293 | 0294 | 0295 | 0296 | 0297 | 0298 | 0299 | 0300 | 0301 | 0302 | 0303 |
| 13 | 0304 | 0305 | 0306 | 0307 | 0308 | 0309 | 0310 | 0311 | 0312 | 0313 | 0314 | 0315 | 0316 | 0317 | 0318 | 0319 |
| 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 | 0353 | 0354 | 0355 | 0356 | 0357 | 0358 | 0359 | 0360 | 0361 | 0362 | 0363 | 0364 | 0365 | 0366 | 0367 |
| 17 | 0368 | 0369 | 0370 | 0371 | 0372 | 0373 | 0374 | 0375 | 0376 | 0377 | 0378 | 0379 | 0380 | 0381 | 0382 | 0383 |
| 18 | 0384 | 0385 | 0386 | 0387 | 0388 | 0389 | 0390 | 0391 | 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 |
| 1 B | 0432 | 0433 | 0434 | 0435 | 0436 | 0437 | 0438 | 0439 | 0440 | 0441 | 0442 | 0443 | 0444 | 0445 | 0446 | 0447 |
| 1 C | 0448 | 0449 | 0450 | 0451 | 0452 | 0453 | 0454 | 0455 | 0456 | 0457 | 0458 | 0459 | 0460 | 0461 | 0462 | 0463 |
| 1 D | 0464 | 0465 | 0466 | 0467 | 0468 | 0469 | 0470 | 0471 | 0472 | 0473 | 0474 | 0475 | 0476 | $0477^{\circ}$ | 0478 | 0479 |
| $1 E$ | 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 | 0514 |


|  | 0 | 1 | 2 | 3 | 4 | 5 | 6 | 7 | 8 | 9 | A | B | C | 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 | 0545 | 0546 | 0547 | 0548 | 0549 | 0550 | 0551 | 0552 | 0553 | 0554 | 0555 | 0556 | 0557 | 0558 | 0559 |
| 23 | 0560 | 0561 | 0562 | 0563 | 0564 | 0565 | 0566 | 0567 | 0568 | 0569 | 0570 | 0571 | 0572 | 0573 | 0574 | 0575 |
| 24 | 0576 | 0577 | 0578 | 0579 | 0580 | 0581 | 0582 | 0583 | 0584 | 0585 | 0586 | 0587 | 0588 | 0589 | 0590 | 0591 |
| 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 | 0624 | 0625 | 0626 | 0627 | 0628 | 0629 | 0630 | 0631 | 0632 | 0633 | 0634 | 0635 | 0636 | 0637 | 0638 | 0639 |
| 28 | 0640 | 0641 | 0642 | 0643 | 0644 | 0645 | 0646 | 0647 | 0648 | 0649 | 0650 | 0651 | 0652 | 0653 | 0654 | 0655 |
| 29 | 0656 | 0657 | 0658 | 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 |
| $2 B$ | 0688 | 0689 | 0690 | 0691 | 0692 | 0693 | 0694 | 0695 | 0696 | 0697 | 0698 | 0699 | 0700 | 0701 | 0702 | 0703 |
| 2C | 0704 | 0705 | 0706 | 0707 | 0708 | 0709 | 0710 | 0711 | 0712 | 0713 | 0714 | 0715 | 0716 | 0717 | 0718 | 0719 |
| 2D | 0720 | 0721 | 0722 | 0723 | 0724 | 0725 | 0726 | 0727 | 0728 | 0729 | 0730 | 0731 | 0732 | 0733 | 0734 | 0735 |
| 2 E | 0736 | 0737 | 0738 | 0739 | 0740 | 0741 | 0742 | 0743 | 0744 | 0745 | 0746 | 0747 | 0748 | 0749 | 0750 | 0751 |
| 2 F | 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 | B | C | 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 | 0801 | 0802 | 0803 | 0804 | 0805 | 0806 | 0807 | 0808 | 0809 | 0810 | 0811 | 0812 | 0813 | 0814 | 0815 |
| 33 | 0816 | 0817 | 0818 | 0819 | 0820 | 0821 | 0822 | 0823 | 0824 | 0825 | 0826 | 0827 | 0828 | 0829 | 0830 | 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 | 0880 | 0881 | 0882 | 0883 | 0884 | 0885 | 0886 | 0887 | 0888 | 0889 | 0890 | 0891 | 0892 | 0893 | 0894 | 0895 |
| 38 | 0896 | 0897 | 0898 | 0899 | 0900 | 0901 | 0902 | 0903 | 0904 | 0905 | 0906 | 0907 | 0908 | 0909 | 0910 | 0911 |
| 39 | 0912 | 0913 | 0914 | 0915 | 0916 | 0917 | 0918 | 0919 | 0920 | 0921 | 0922 | 0923 | 0924 | 0925 | 0926 | 0927 |
| 3 A | 0928 | 0929 | 0930 | 0931 | 0932 | 0933 | 0934 | 0935 | 0936 | 0937 | 0938 | 0939 | 0940 | 0941 | 0942 | 0943 |
| 3B | 0944 | 0945 | 0946 | 0947 | 0948 | 0949 | 0950 | 0951 | 0952 | 0953 | 0954 | 0955 | 0956 | 0957 | 0958 | 0959 |
| 3C | 0960 | 0961 | 0962 | 0963 | 0964 | 0965 | 0966 | 0967 | 0968 | 0969 | 0970 | 0971 | 0972 | 0973 | 0974 | 0975 |
| 3 D | 0976 | 0977 | 0978 | 0979 | 0980 | 0981 | 0982 | 0983 | 0984 | 0985 | 0986 | 0987 | 0988 | 0989 | 0990 | 0991 |
| 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 |

HEXADECIMAL-DECIMAL INTEGER CONVERSION (Part 2 of 4)

|  | 0 | 1 | 2 | 3 | 4 | 5 | 6 | 7 | 8 | 9 | A | B | c | 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 | 1062 | 1063 | 1064 | 1065 | 1066 | 1067 | 1068 | 1069 | 1070 | 1071 |
| 43 | 1072 | 1073 | 1074 | 1075 | 1076 | 1077 | 1078 | 1079 | 1080 | 1081 | 1082 | 1083 | 1084 | 1085 | 1086 | 1087 |
| 44 | 1088 | 1089 | 1090 | 1091 | 1092 | 1093 | 1094 | 1095 | 1096 | 1097 | 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 | 1152 | 1153 | 1154 | 1155 | 1156 | 1157 | 1158 | 1159 | 1160 | 1161 | 1162 | 1163 | 1164 | 1165 | 1166 | 1167 |
| 49 | 1168 | 1169 | 1170 | 1171 | 1172 | 1173 | 1174 | 1175 | 1176 | 1177 | 1178 | 1179 | 1180 | 1181 | 1182 | 1183 |
| 4A | 1184 | 1185 | 1186 | 1187 | 1188 | 1189 | 1190 | 1191 | 1192 | 1193 | 1194 | 1195 | 1196 | 1197 | 1198 | 1199 |
| 4 B | 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 | 1232 | 1233 | 1234 | 1235 | 1236 | 1237 | 1238 | 1239 | 1240 | 1241 | 1242 | 1243 | 1244 | 1245 | 1246 | 1247 |
| 4 E | 1248 | 1249 | 1250 | 1251 | 1252 | 1253 | 1254 | 1255 | 1256 | 1257 | 1258 | 1259 | 1260 | 1261 | 1262 | 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 | A | B | C | 0 | 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 | 1344 | 1345 | 1346 | 1347 | 1348 | 1349 | 1350 | 1351 | 1352 | 1353 | 1354 | 1355 | 1356 | 1357 | 1358 | 1359 |
| 55 | 1360 | 1361 | 1362 | 1363 | 1364 | 1365 | 1366 | 1367 | 1368 | 1369 | 1370 | 1371 | 1372 | 1373 | 1374 | 1375 |
| 56 | 1376 | 1377 | 1378 | 1379 | 1380 | 1381 | 1382 | 1383 | 1384 | 1385 | 1386 | 1387 | 1388 | 1389 | 1390 | 1391 |
| 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 | 1440 | 1441 | 1442 | 1443 | 1444 | 1445 | 1446 | 1447 | 1448 | 1449 | 1450 | 1451 | 1452 | 1453 | 1454 | 1455 |
| 5B | 1456 | 1457 | 1458 | 1459 | 1460 | 1461 | 1462 | 1463 | 1464 | 1465 | 1466 | 1467 | 1468 | 1469 | 1470 | 1471 |
| 5 C | 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 |
| 5 E | 1504 | 1505 | 1506 | 1507 | 1508 | 1509 | 1510 | 1511 | 1512 | 1513 | 1514 | 1515 | 1516 | 1517 | 1518 | 1519 |
| 5 F | 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 | A | B | C | 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 | 1568 | 1569 | 1570 | 1571 | 1572 | 1573 | 1574 | 1575 | 1576 | 1577 | 1578 | 1579 | 1580 | 1581 | 1582 | 1583 |
| 63 | 1584 | 1585 | 1586 | 1587 | 1588 | 1589 | 1590 | 1591 | 1592 | 1593 | 1594 | 1595 | 1596 | 1597 | 1598 | 1599 |
| 64 | 1600 | 1601 | 1602 | 1603 | 1604 | 1605 | 1606 | 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 | 1664 | 1665 | 1666 | 1667 | 1668 | 1669 | 1670 | 1671 | 1672 | 1673 | 1674 | 1675 | 1676 | 1677 | 1678 | 1679 |
| 69 | 1680 | 1681 | 1682 | 1683 | 1684 | 1685 | 1686 | 1687 | 1688 | 1689 | 1690 | 1691 | 1692 | 1693 | 1694 | 1695 |
| 6A | 1696 | 1697 | 1698 | 1699 | 1700 | 1701 | 1702 | 1703 | 1704 | 1705 | 1706 | 1707 | 1708 | 1709 | 1710 | 1711 |
| 68 | 1712 | 1713 | 1714 | 1715 | 1716 | 1717 | 1718 | 1719 | 1720 | 1721 | 1722 | 1723 | 1724 | 1725 | 1726 | 1727 |
| 6 C | 1728 | 1729 | 1730 | 1731 | 1732 | 1733 | 1734 | 1735 | 1736 | 1737 | 1738 | 1739 | 1740 | 1741 | 1742 | 1743 |
| 60 | 1744 | 1745 | 1746 | 1747 | 1748 | 1749 | 1750 | 1751 | 1752 | 1753 | 1754 | 1755 | 1756 | 1757 | 1758 | 1759 |
| 6 E | 1760 | 1761 | 1762 | 1763 | 1764 | 1765 | 1766 | 1767 | 1768 | 1769 | 1770 | 1771 | 1772 | 1773 | 1774 | 1775 |
| 6 F | 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 | A | B | C | 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 | 1840 | 1841 | 1842 | 1843 | 1844 | 1845 | 1846 | 1847 | 1848 | 1849 | 1850 | 1851 | 1852 | 1853 | 1854 | 1855 |
| 74 | 1856 | 1857 | 1858 | 1859 | 1860 | 1861 | 1862 | 1863 | 1864 | 1865 | 1866 | 1867 | 1868 | 1869 | 1870 | 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 | 1920 | 1921 | 1922 | 1923 | 1924 | 1925 | 1926 | 1927 | 1928 | 1929 | 1930 | 1931 | 1932 | 1933 | 1934 | 1935 |
| 79 | 1936 | 1937 | 1938 | 1939 | 1940 | 1941 | 1942 | 1943 | 1944 | 1945 | 1946 | 1947 | 1948 | 1949 | 1950 | 1951 |
| 7 A | 1952 | 1953 | 1954 | 1955 | 1956 | 1957 | 1958 | 1959 | 1960 | 1961 | 1962 | 1963 | 1964 | 1965 | 1966 | 1967 |
| 78 | 1968 | 1969 | 1970 | 1971 | 1972 | 1973 | 1974 | 1975 | 1976 | 1977 | 1978 | 1979 | 1980 | 1981 | 1982 | 1983 |
| 7 C | 1984 | 1985 | 1986 | 1987 | 1988 | 1989 | 1990 | 1991 | 1992 | 1993 | 1994 | 1995 | 1996 | 1997 | 1998 | 1999 |
| 70 | 2000 | 2001 | 2002 | 2003 | 2004 | 2005 | 2006 | 2007 | 2008 | 2009 | 2010 | 2011 | 2012 | 2013 | 2014 | 2015 |
| 7E | 2016 | 2017 | 2018 | 2019 | 2020 | 2021 | 2022 | 2023 | 2024 | 2025 | 2026 | 2027 | 2028 | 2029 | 2030 | 2031 |
| 7F | 2032 | 2033 | 2034 | 2035 | 2036 | 2037 | 2038 | 2039 | 2040 | 2041 | 2042 | 2043 | 2044 | 2045 | 2046 | 2047 |

HEXADECIMAL-DECIMAL INTEGER CONVERSION (Part 3 of 4)

|  | 0 | 1 | 2 | 3 | 4 | 5 | 6 | 7 | 8 | 9 | A | B | C | 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 | 2094 | 2095 |
| 83 | 2096 | 2097 | 2098 | 2099 | 2100 | 2101 | 2102 | 2103 | 2104 | 2105 | 2106 | 2107 | 2108 | 2109 | 2110 | 2111 |
| 84 | 2112 | 2113 | 2114 | 2115 | 2116 | 2117 | 2118 | 2119 | 2120 | 2121 | 2122 | 2123 | 2124 | 2125 | 2126 | 2127 |
| 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 | 2176 | 2177 | 2178 | 2179 | 2130 | 2181 | 2182 | 2183 | 2184 | 2185 | 2186 | 2187 | 2188 | 2189 | 2190 | 2191 |
| 89 | 2192 | 2193 | 2194 | 2195 | 2196 | 2197 | 2198 | 2199 | 2200 | 2201 | 2202 | 2203 | 2204 | 2205 | 2206 | 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 |
| 8 C | 2240 | 2241 | 2242 | 2243 | 2244 | 2245 | 2246 | 2247 | 2248 | 2249 | 2250 | 2251 | 2252 | 2253 | 2254 | 2255 |
| 80 | 2256 | 2257 | 2258 | 2259 | 2260 | 2261 | 2262 | 2263 | 2264 | 2265 | 2266 | 2267 | 2268 | 2269 | 2270 | 2271 |
| 8 E | 2272 | 2273 | 2274 | 2275 | 2276 | 2277 | 2278 | 2279 | 2280 | 2281 | 2282 | 2283 | 2284 | 2285 | 2286 | 2287 |
| 8F | 2288 | 2289 | 2290 | 2291 | 2292 | 2293 | 2294 | 2295 | 2296 | 2297 | 2298 | 2299 | 2300 | 2301 | 2302 | 2303 |
|  | 0 | 1 | 2 | 3 | 4 | 5 | 6 | 7 | 8 | 9 | A | B | C | 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 | 2326 | 2327 | 2328 | 2329 | 2330 | 2331 | 2332 | 2333 | 2334 | 2335 |
| 92 | 2336 | 2337 | 2338 | 2339 | 2340 | 2341 | 2342 | 2343 | 2344 | 2345 | 2346 | 2347 | 2348 | 2349 | 2350 | 2351 |
| 93 | 2352 | 2353 | 2354 | 2355 | 2356 | 2357 | 2358 | 2359 | 2360 | 2361 | 2362 | 2363 | 2364 | 2365 | 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 | 2418 | 2419 | 2420 | 2421 | 2422 | 2423 | 2424 | 2425 | 2426 | 2427 | 2428 | 2429 | 2430 | 2431 |
| 98 | 2432 | 2433 | 2434 | 2435 | 2436 | 2437 | 2438 | 2439 | 2440 | 2441 | 2442 | 2443 | 2444 | 2445 | 2446 | 2447 |
| 99 | 2448 | 2449 | 2450 | 2451 | 2452 | 2453 | 2454 | 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 |
| 98 | 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 |
| 9 D | 2512 | 2513 | 2514 | 2515 | 2516 | 2517 | 2518 | 2519 | 2520 | 2521 | 2522 | 2523 | 2524 | 2525 | 2526 | 2527 |
| 9 E | 2528 | 2529 | 2530 | 2531 | 2532 | 2533 | 2534 | 2535 | 2536 | 2537 | 2538 | 2539 | 2540 | 2541 | 2542 | 2543 |
| 9 F | 2544 | 2545 | 2546 | 2547 | 2548 | 2549 | 2550 | 2551 | 2552 | 2553 | 2554 | 2555 | 2556 | 2557 | 2558 | 2559 |
|  | 0 | 1 | 2 | 3 | 4 | 5 | 6 | 7 | 8 | 9 | A | B | C | D | E | F |
| AO | 2560 | 2561 | 2562 | 2563 | 2564 | 2565 | 2566 | 2567 | 2568 | 2569 | 2570 | 2571 | 2572 | 2573 | 2574 | 2575 |
| A1 | 2576 | 2577 | 2578 | 2579 | 2580 | 2581 | 2582 | 2583 | 2584 | 2585 | 2586 | 2587 | 2588 | 2589 | 2590 | 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 | 2640 | 2641. | 2642 | 2643 | 2644 | 2645 | 2646 | 2647 | 2648 | 2649 | 2650 | 2651 | 2652 | 2653 | 2654 | 2655 |
| A6 | 2656 | 2657 | 2658 | 2659 | 2660 | 2661 | 2662 | 2663 | 2664 | 2665 | 2666 | 2667 | 2668 | 2669 | 2670 | 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 | 2737 | 2738 | 2739 | 2740 | 2741 | 2742 | 2743 | 2744 | 2745 | 2746 | 2747 | 2748 | 2749 | 2750 | 2751 |
| ACO | 2752 | 2753 | 2754 | 2755 | 2756 | 2757 | 2758 | 2759 | 2760 | 2761 | 2762 | 2763 | 2764 | 2765 | 2766 | 2767 |
| ADO | 2768 | 2769 | 2770 | 2771 | 2772 | 2773 | 2774 | 2775 | 2776 | 2777 | 2778 | 2779 | 2780 | 2781 | 2782 | 2783 |
| AEO | 2784 | 2785 | 2786 | 2787 | 2788 | 2789 | 2790 | 2791 | 2792 | 2793 | 2794 | 2795 | 2796 | 2797 | 2798 | 2799 |
| AFO | 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 | A | B | C | D | E | F |
| B0 | 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 | 2864 | 2865 | 2866 | 2867 | 2868 | 2869 | 2870 | 2871 | 2872 | 2873 | 2874 | 2875 | 2876 | 2877 | 2878 | 2879 |
| B4 | 2880 | 2881 | 2882 | 2883 | 2884 | 2885 | 2886 | 2887 | 2888 | 2889 | 2890 | 2891 | 2892 | 2893 | 2894 | 2895 |
| B5 | 2896 | 2897 | 2898 | 2899 | 2900 | 2901 | 2902 | 2903 | 2904 | 2905 | 2906 | 2907 | 2908 | 2909 | 2910 | 2911 |
| B6 | 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 | 2944 | 2945 | 2946 | 2947 | 2948 | 2949 | 2950 | 2951 | 2952 | 2953 | 2954 | 2955 | 2956 | 2957 | 2958 | 2959 |
| B9 | 2960 | 2961 | 2962 | 2963 | 2964 | 2965 | 2966 | 2967 | 2968 | 2969 | 2970 | 2971 | 2972 | 2973 | 2974 | 2975 |
| BA | 2976 | 2977 | 2978 | 2979 | 2980 | 2981 | 2982 | 2983 | 2984 | 2985 | 2986 | 2987 | 2988 | 2989 | 2990 | 2991 |
| BB | 2992 | 2993 | 2994 | 2995 | 2996 | 2997 | 2998 | 2999 | 3000 | 3001 | 3002 | 3003 | 3004 | 3005 | 3006 | 3007 |
| BC | 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 | 3040 | 3041 | 3042 | 3043 | 3044 | 3045 | 3046 | 3047 | 3048 | 3049 | 3050 | 3051 | 3052 | 3053 | 3054 | 3055 |
| BF | 3056 | 3057 | 3058 | 3059 | 3060 | 3061 | 3062 | 3063 | 3064 | 3065 | 3066 | 3067 | 3068 | 3069 | 3070 | 3071 |

HEXADECIMAL-DECIMAL INTEGER CONVERSION (Part 4 of 4)

|  | 0 | 1 | 2 | 3 | 4 | 5 | 6 | 7 | 8 | 9 | A | 8 | C | D | E | $F$ |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| C0 | 3072 | 3073 | 3074 | 3075 | 3076 | 3077 | 3078 | 3079 | 3080 | 3081 | 3082 | 3083 | 3084 | 3085 | 3086 | 3087 |
| C1 | 3088 | 3089 | 3090 | 3091 | 3092 | 3093 | 3094 | 3095 | 3096 | 3097 | 3098 | 3099 | 3100 | 3101 | 3102 | 3103 |
| C2 | 3104 | 3105 | 3106 | 3107 | 3108 | 3109 | 3110 | 3111 | 3112 | 3113 | 3114 | 3115 | 3116 | . 3117 | 3118 | 3119 |
| C3 | 3120 | 3121 | 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 | 3152 | 3153 | 3154 | 3155 | 3156 | 3157 | 3158 | 3159 | 3160 | 3161 | 3162 | 3163 | 3164 | 3165 | 3166 | 3167 |
| C6 | 3168 | 3169 | 3170 | 3171 | 3172 | 3173 | 3174 | 3175 | 3176 | 3177 | 3178 | 3179 | 3180 | 3181 | 3182 | 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 | 3224 | 3225 | 3226 | 3227 | 3228 | 3229 | 3230 | 3231 |
| CA | 3232 | 3233 | 3234 | 3235 | 3236 | 3237 | 3238 | 3239 | 3240 | 3241 | 3242 | 3243 | 3244 | 3245 | 3246 | 3247 |
| C8 | 3248 | 3249 | 3250 | 3251 | 3252 | 3253 | 3254 | 3255 | 3256 | 3257 | 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 | 3296 | 3297 | 3298 | 3299 | 3300 | 3301 | 3302 | 3303 | 3304 | 3305 | 3306 | 3307 | 3308 | 3309 | 3310 | 3311 |
| CF | 3312 | 3313 | 3314 | 3315 | 3316 | 3317 | 3318 | 3319 | 3320 | 3321 | 3322 | 3323 | 3324 | 3325 | 3326 | 3327 |
|  | 0 | 1 | 2 | 3 | 4 | 5 | 6 | 7 | 8 | 9 | A | B | C | D | E | F |
| D0 | 3328 | 3329 | 3330 | 3331 | 3332 | 3333 | 3334 | 3335 | 3336 | 3337 | 3338 | 3339 | 3340 | 3341 | 3342 | 3343 |
| D1 | 3344 | 3345 | 3346 | 3347 | 3348 | 3349 | 3350 | 3351 | 3352 | 3353 | 3354 | 3355 | 3356 | 3357 | 3358 | 3359 |
| D2 | 3360 | 3361 | 3362 | 3363 | 3364 | 3365 | 3366 | 3367 | 3368 | 3369 | 3370 | 3371 | 3372 | 3373 | 3374 | 3375 |
| D3 | 3376 | 3377 | 3378 | 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 | 3425 | 3426 | 3427 | 3428 | 3429 | 3430 | 3431 | 3432 | 3433 | 3434 | 3435 | 3436 | 3437 | 3438 | 3439 |
| D7 | 3440 | 3441 | 3442 | 3443 | 3444 | 3445 | 3446 | 3447 | 3448 | 3449 | 3450 | 3451 | 3452 | 3453 | 3454 | 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 |
| DB | 3504 | 3505 | 3506 | 3507 | 3508 | 3509 | 3510 | 3511 | 3512 | 3513 | 3514 | 3515 | 3516 | 3517 | 3518 | 3519 |
| DC | 3520 | 3521 | 3522 | 3523 | 3524 | 3525 | 3526 | 3527 | 3528 | 3529 | 3530 | 3531 | 3532 | 3533 | 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 | A | B | C | D | E | F |
| E0 | 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 | 3617 | 3618 | 3619 | 3620 | 3621 | 3622 | 3623 | 3624 | 3625 | 3626 | 3627 | 3628 | 3629 | 3630 | 3631 |
| E3 | 3632 | 3633 | 3634 | 3635 | 3636 | 3637 | 3638 | 3639 | 3640 | 3641 | 3642 | 3643 | 3644 | 3645 | 3646 | 3647 |
| E4 | 3648 | 3649 | 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 | 3697 | 3698 | 3699 | 3700 | 3701 | 3702 | 3703 | 3704 | 3705 | 3706 | 3707 | 3708 | 3709 | 3710 | 3711 |
| E8 | 3712 | 3713 | 3714 | 3715 | 3716 | 3717 | 3718 | 3719 | 3720 | 3721 | 3722 | 3723 | 3724 | 3725 | 3726 | 3727 |
| E9 | 3728 | 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 |
| EC | 3776 | 3777 | 3778 | 3779 | 3780 | 3781 | 3782 | 3783 | 3784 | 3785 | 3786 | 3787 | 3788 | 3789 | 3790 | 3791 |
| ED | 3792 | 3793 | 3794 | 3795 | 3796 | 3797 | 3798 | 3799 | 3800 | 3801 | 3802 | 3803 | 3804 | 3805 | 3806 | 3807 |
| 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 | A | B | c | 0 | 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 | 3872 | 3873 | 3874 | 3875 | 3876 | 3877 | 3878 | 3879 | 3880 | 3881 | 3882 | 3883 | 3884 | 3885 | 3886 | 3887 |
| F3 | 3888 | 3889 | 3890 | 3891 | 3892 | 3893 | 3894 | 3895 | 3896 | 3897 | 3898 | 3899 | 3900 | 3901 | 3902 | 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 | 3952 | 3953 | 3954 | 3955 | 3956 | 3957 | 3958 | 3959 | 3960 | 3961 | 3962 | 3963 | 3964 | 3965 | 3966 | 3967 |
| F8 | 3968 | 3969 | 3970 | 3971 | 3972 | 3973 | 3974 | 3975 | 3976 | 3977 | 3978 | 3979 | 3980 | 3981 | 3982 | 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 |
| FC | 4032 | 4033 | 4034 | 4035 | 4036 | 4037 | 4038 | 4039 | 4040 | 4041 | 4042 | 4043 | 4044 | 4045 | 4046 | 4047 |
| FD | 4048 | 4049 | 4050 | 4051 | 4052 | 4053 | 4054 | 4055 | 4056 | 4057 | 4058 | 4059 | 4060 | 4061 | 4062 | 4063 |
| FE | 4064 | 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 |

## C.2. HEXADECIMAL FRACTIONS (APPROXIMATE VALUES)

| First Digit |  | Second Digit |  |  | Third Digit |  |  |  | Fourth Digit |  |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| Hex. | Decimal | Hex. | Decimal |  | Hex. | Decimal |  |  | Hex. | 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 |
| . | . 6250 | . OA | . 0390 | 6250 | .00A | . 0024 | 4140 | 6250 | .000A | . 0001 | 5258 | 7891 |
| . $B$ | . 6875 | . OB | . 0429 | 6875 | . 00 B | . 0026 | 8554 | 6875 | .000B | . 0001 | 6784 | 6680 |
| . C | . 7500 | . OC | . 0468 | 7500 | .00C | . 0029 | 2968 | 7500 | .000C | . 0001 | 8310 | 5469 |
| . | . 8125 | . OD | . 0507 | 8125 | .000 | . 0031 | 7382 | 8125 | . 00000 | . 0001 | 9836 | 4258 |
| . E | . 8750 | . 0 E | . 0546 | 8750 | . 00 E | . 0034 | 1796 | 8750 | .000E | . 0002 | 1362 | 3047 |
| .F | . 9375 | . OF | . 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.

| .B | from the table equals | .6875 |
| :--- | :--- | :--- |
| .05 | from the table equals | .01953125 |
| $.00 A$ | from the table equals | .002441406250 |
| .0001 | from the table equals | .000015258789 |
|  |  | .709487915039 |

## C.3. POWERS OF 2

|  |  |  | $2^{\text {n }}$ | $n$ | $2^{-n}$ |  |  |  |  |  |  |  |  |  |  |  |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  | 1 | 0 | 1.0 |  |  |  |  |  |  |  |  |  |  |  |  |  |
|  |  |  | 2 | 1 | 0.5 |  |  |  |  |  |  |  |  |  |  |  |  |  |
|  |  |  | 4 | 2 | 0.25 |  |  |  |  |  |  |  |  |  |  |  |  |  |
|  |  |  | 8 | 3 | 0.125 |  |  |  |  |  |  |  |  |  |  |  |  |  |
|  |  |  | 16 | 4 | 0.062 | 5 |  |  |  |  |  |  |  |  |  |  |  |  |
|  |  |  | 32 | 5 | 0.031 | 25 |  |  |  |  |  |  |  |  |  |  |  |  |
|  |  |  | 64 | 6 | 0.015 | 625 |  |  |  |  |  |  |  |  |  |  |  |  |
|  |  |  | 128 | 7 | 0.007 | 812 | 5 |  |  |  |  |  |  |  |  |  |  |  |
|  |  |  | 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 |  |  |  |  |  |  |  |  |  |  |
|  |  | 4 | 096 | 12 | 0.000 | 244 | 140 | 625 |  |  |  |  |  |  |  |  |  |  |
|  |  | 8 | 192 | 13 | 0.000 | 122 | 070 | 312 | 5 |  |  |  |  |  |  |  |  |  |
|  |  | 16 | 384 | 14 | 0.000 | 061 | 035 | 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 | 001 | 907 | 348 | 632 | 812 | 5 |  |  |  |  |  |  |  |
|  | 1 | 048 | 576 | 20 | 0.000 | 000 | 953 | 674 | 316 | 406 | 25 |  |  |  |  |  |  |  |
|  | 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 |  |  |  |  |  |  |
|  | 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 |  |  |  |  |  |
|  | 67 | 108 | 864 | 26 | 0.000 | 000 | 014 | 901 | 161 | 193 | 847 | 656 | 25 |  |  |  |  |  |
|  | 134 | 217 | 728 | 27 | 0.000 | 000 | 007 | 450 | 580 | 596 | 923 | 828 | 125 |  |  |  |  |  |
|  | 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 | 25 |  |  |  |  |
| 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 |  |  |  |
| 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 |  |  |
| 34 | 359 | 738 | 368 | 35 | 0.000 | 000 | 000 | 029 | 103 | 830 | 456 | 733 | 703 | 613 | 281 | 25 |  |  |
| 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 |  |
| 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 |  |
| 099 | 511 | 627 | 776 | 40 | 0.000 | 000 | 000 | 000 | 909 | 494 | 701 | 772 | 928 | 237 | 915 | 039 | 062 | 5 |

## C.4. POWERS OF 16



These powers of 16 are especially useful in determining the value of floating-point numbers.

# Appendix D. Check-Off Table Terms 



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

The check-off table is a fast reference source for its associated instruction. The table points where to look for possible errors when writing your programs and helps you debug your program when it does not run correctly. A program interrupt occurs when the hardware detects an improper specification, use of instructions or data. Interrupt requests of this type cause the instruction currently being executed to be suppressed or terminated. When a table is used with an instruction, the checked ( $■$ ) condition codes and program exceptions are the only ones that apply to that instruction. The program exceptions are explained in the following list, as well as the instruction to which it applies.

## - 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 operation exceeds 127.

- Exponent Underflow

The final characteristic resulting from a floating-point arithmetic operation is less than zero.

- Fixed-Point Divide

The quotient of a fixed-point divide operation exceeds the capacity of the first operand (including division by zero) by 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_{1}$ 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 E. Instruction Listings

Included in this appendix are alphabetic listings of the mnemonic codes (Table E-1) and instruction names (Table E-2) and a numeric list of the machine codes (Table E-3). In Tables E-2 and E-3, unless otherwise indicated, mnemonic instructions are available in native mode only.

Table E-1. Mnemonic List of Instructions (Part 1 of 4)

| Mnemonic | Instruction Name | Machine Code | Byte Length | Source Code Format |  |
| :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  |  | Explicit | Implicit |
| A | Add | 5A | 4 | $\mathrm{r}_{1}, \mathrm{~d}_{2}\left(\mathrm{x}_{2}, \mathrm{~b}_{2}\right)$ | $r_{1} s_{2}\left(x_{2}\right)$ |
| AD | Add Normalized, Long | 6A | 4 | $r_{1}, d_{2}\left(x_{2}, b_{2}\right)$ | $r_{1}, s_{2}\left(x_{2}\right)$ |
| ADR | Add Normalized, Long | 2A | 2 | $\mathrm{r}_{1}, \mathrm{r}_{2}$ | $r_{1}, r_{2}$ |
| AE | Add Normalized, Short | 7A | 4 | $\mathrm{r}_{1}, \mathrm{~d}_{2}\left(\mathrm{x}_{2}, \mathrm{~b}_{2}\right)$ | $r_{1}, s_{2}\left(x_{2}\right)$ |
| AER | Add Normalized, Short | 3A | 2 | $\mathrm{r}_{1}, \mathrm{r}_{2}$ | $r_{1}, r_{2}$ |
| AH | Add Half Word | 4A | 4 | $\mathrm{r}_{1}, \mathrm{~d}_{2}\left(\mathrm{x}_{2}, \mathrm{~b}_{2}\right)$ | $\mathrm{r}_{1}, s_{2}\left(x_{2}\right)$ |
| AI | Add Immediate | 9A | 4 | $d_{1}\left(b_{1}\right), i_{2}$ | $\mathrm{s}_{1}, \mathrm{i}_{2}$ |
| AL | Add Logical | 5E | 4 | $\mathrm{r}_{1}, \mathrm{~d}_{2}\left(\mathrm{x}_{2}, \mathrm{~b}_{2}\right)$ | $r_{1}, s_{2}\left(x_{2}\right)$ |
| ALR | Add Logical | 1E | 2 | $\mathrm{r}_{1}, \mathrm{r}$ | ${ }^{1}, r_{2}$ |
| AP | Add Decimal | FA | 6 | $d_{1}\left(1 l_{1}, b_{1}\right), d_{2}\left(l_{2}, b_{2}\right)$ | $s_{1}\left(11_{1}\right), s_{2}\left(1 l_{2}\right)$ |
| AR | Add | 1A | 2 | $r_{1}, r_{2}$ | $r_{1}, r_{2}$ |
| AU | Add Unnormalized, Short | 7E | 4 | $\mathrm{r}_{1}, \mathrm{~d}_{2}\left(\mathrm{x}_{2}, \mathrm{~b}_{2}\right)$ | $r_{1}, s_{2}\left(x_{2}\right)$ |
| AUR | Add Unnormalized, Short | 3E | 2 | $r_{1}, r_{2}$ | $\mathrm{r}_{1}, \mathrm{r}_{2}$ |
| AW | Add Unnormalized, Long | 6E | 4 | $\mathrm{r}_{1}, \mathrm{~d}_{2}\left(\mathrm{x}_{2}, \mathrm{~b}_{2}\right)$ | $r_{1}, s_{2}\left(x_{2}\right)$ |
| AWR | Add Unnormalized, Long | 2E | 2 | $\mathrm{r}_{1}, r_{2}$ | $\mathrm{r}_{1}, \mathrm{r}_{2}$ |
| BAL | Branch and Link | 45 | 4 | $r_{1}, d_{2}\left(x_{2}, b_{2}\right)$ | $r_{1}, s_{2}\left(x_{2}\right)$ |
| BALR | Branch and Link | 05 | 2 | $r_{1}, r_{2}$ | $r_{1}, r_{2}$ |
| BAS | Branch and Store | 4D | 4 | $\{$ compatibility $\}$ |  |
| BASR | Branch and Store | OD | 2 | $\{$ mode only $\}$ |  |
| BC | Branch on Condition | 47 | 4 | $\mathrm{i}, \mathrm{d}_{2}\left(\mathrm{x}_{2}, \mathrm{~b}_{2}\right)$ | i, $\mathrm{s}_{2}\left(\mathrm{x}_{2}\right)$ |
| BCR | Branch on Condition | 07 | 2 | i, $\mathrm{r}_{2}$ | i, $r_{2}$ |
| BCT | Branch on Count | 46 | 4 | $\mathrm{r}_{1}, \mathrm{~d}_{2}\left(\mathrm{x}_{2}, \mathrm{~b}_{2}\right)$ | $r_{1}, s_{2}\left(x_{2}\right)$ |
| BCTR | Branch on Count | 06 | 2 | $r_{1}, r_{2}$ | $r_{1}, r_{2}$ |
| BXH | Branch on Index High | 86 | 4 | $r_{1}, r_{3}, d_{2}\left(b_{2}\right)$ | $r_{1}, r_{3}, s_{2}$ |
| BXLE | Branch on Index Low or Equal | 87 | 4 | $r_{1}, r_{3}, d_{2}\left(b_{2}\right)$ | $\mathrm{r}_{1}, r_{3}{ }^{\text {, }}{ }^{\text {r }}$ |
| C | Compare Algebraic | 59 | 4 | $\mathrm{r}_{1}, \mathrm{~d}_{2}\left(\mathrm{x}_{2}, \mathrm{~b}_{2}\right)$ | $r_{1}, s_{2}\left(x_{2}\right)$ |
| CD | Compare, Long | 69 | 4 | $\mathrm{r}_{1}, \mathrm{~d}_{2}\left(\mathrm{x}_{2}, \mathrm{~b}_{2}\right)$ | $r_{1}, s_{2}\left(x_{2}\right)$ |
| CDR | Compare, Long | 29 | 2 | $\mathrm{r}_{1} \mathrm{r}_{2}$ | $r_{1}, r_{2}$ |
| CE | Compare, Short | 79 | 4 | $\mathrm{r}_{1}, \mathrm{~d}_{2}\left(\mathrm{x}_{2}, \mathrm{~b}_{2}\right)$ | $r_{1}, s_{2}\left(x_{2}\right)$ |
| CER | Compare, Short | 39 | 2 | $\mathrm{r}_{1}, \mathrm{r}_{2}$ | $r_{1}, r_{2}$ |
| CH | Compare Half Word | 49 | 4 | $\mathrm{r}_{1}, \mathrm{~d}_{2}\left(\mathrm{x}_{2}, \mathrm{~b}_{2}\right)$ | $r_{1}, s_{2}\left(x_{2}\right)$ |
| CL | Compare Logical | 55 | 4 | $\mathrm{r}_{1}, \mathrm{~d}_{2}\left(\mathrm{x}_{2}, \mathrm{~b}_{2}\right)$ | $r_{1}, s_{2}\left(x_{2}\right)$ |
| CLC | Compare Logical | D5 | 6 | $d_{1},\left(1, b_{1}\right), d_{2}\left(b_{2}\right)$ | $\mathrm{s}_{1}(1), s_{2}$ |
| CLI | Compare Logical Immediate | 95 | 4 | $d_{1}\left(b_{1}\right), i_{2}$ | $\mathrm{s}_{1}, \mathrm{i}_{2}$ |

Table E-1. Mnemonic List of Instructions (Part 2 of 4)

| Mnemonic | Instruction Name | Machine Code | Byte <br> Length | Source Code Format |  |
| :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  |  | Explicit | Implicit |
| CLR | Compare Logical | 15 | 2 | $r_{1}, r_{2}$ | $r_{1}, r_{2}$ |
| CP | Compare Decimal | F9 | 6 | $d_{1}\left(l_{1}, b_{1}\right), d_{2}\left(l_{2}, b_{2}\right)$ | $s_{1}\left(l_{1}\right), s_{2}\left(l_{2}\right)$ |
| CR | Compare Algebraic | 19 | 2 | $r_{1}, r_{2}$ | $\mathrm{r}_{1}, \mathrm{r}_{2}$ |
| CVB | Convert to Binary | 4F | 4 | $r_{1}, d_{2}\left(x_{2}, b_{2}\right)$ | $r_{1}, s_{2}\left(x_{2}\right)$ |
| CVD | Convert to Decimal | 4E | 4 | $r_{1}, d_{2}\left(x_{2}, b_{2}\right)$ | $r_{1}, s_{2}\left(x_{2}\right)$ |
| D | Divide | 5D | 4 | $r_{1}, d_{2}\left(x_{2}, b_{2}\right)$ | $r_{1}, s_{2}\left(x_{2}\right)$ |
| DD | Divide, Long | 60 | 4 | $r_{1}, d_{2}\left(x_{2}, b_{2}\right)$ | $r_{1}, s_{2}\left(x_{2}\right)$ |
| DDR | Divide, Long | 2D | 2 | $r_{1}, r_{2}$ | $r_{1}, r_{2}$ |
| DE | Divide, Short | 7D | 4 | $r_{1}, d_{2}\left(x_{2}, b_{2}\right)$ | $r_{1}, s_{2}\left(x_{2}\right)$ |
| DER | Divide, Short | 3D | 2 | $r_{1}, r_{2}$ | $r_{1}, r_{2}$ |
| DIAG | Diagnose | 83 | 4 | (Privileged) | (Privileged) |
| DP | Divide Decimal | FD | 6 | $d_{1}\left(l_{1}, b_{1}\right), d_{2}\left(l_{2}, b_{2}\right)$ | $s_{1}\left(l_{1}\right), s_{2}\left(l_{2}\right)$ |
| DR | Divide | 1D | 2 | $r_{1} \cdot r_{2}$ | $r_{1}, r_{2}$ |
| ED | Edit | DE | 6 | $d_{1}\left(1, b_{1}\right), d_{2}\left(b_{2}\right)$ | $s_{1}(1), s_{2}$ |
| EDMK | Edit and Mark | DF | 6 | $d_{1}\left(1, b_{1}\right), d_{2}\left(b_{2}\right)$ | $s_{1}(1), s_{2}$ |
| EX | Execute | 44 | 4 | $r_{1}, d_{2}\left(x_{2}, b_{2}\right)$ | $r_{1}, s_{2}\left(x_{2}\right)$ |
| HDR | Halve, Long | 24 | 2 | $r_{1}, r_{2}$ | $r_{1}, r_{2}$ |
| HER | Halve, Short | 34 | 2 | $r_{1}, r_{2}$ | $r_{1}, r_{2}$ |
| HPR | Halt and Proceed | 99 | 4 | (Privileged) | (Privileged) |
| IC | Insert Character | 43 | 4 | $r_{1}, d_{2}\left(x_{2}, b_{2}\right)$ | $r_{1}, s_{2}\left(x_{2}\right)$ |
| ISK | Insert Storage Key | 09 | 2 | (Privileged) | (Privileged) |
| L | Load | 58 | 4 | $r_{1}, d_{2}\left(x_{2}, b_{2}\right)$ | $\mathrm{r}_{1}, s_{2}\left(x_{2}\right)$ |
| LA | Load Address | 41 | 4 | $r_{1}, d_{2}\left(x_{2}, b_{2}\right)$ | $r_{1}, s_{2}\left(x_{2}\right)$ |
| LCDR | Load Complement, Long | 23 | 2 | $r_{1}, r_{2}$ | $r_{1}, r_{2}$ |
| LCER | Load Complement, Short | 33 | 2 | $r_{1}, r_{2}$ | $r_{1}, r_{2}$ |
| LCR | Load Complement | 13 | 2 | $r_{1}, r_{2}$ | $r_{1}, r_{2}$ |
| LCS | Load Control Storage | B1 | 4 | (Privileged) | (Privileged) |
| LD | Load, Long | 68 | 4 | $r_{1}, d_{2}\left(x_{2}, b_{2}\right)$ | $r_{1}, s_{2}\left(x_{2}\right)$ |
| LDR | Load, Long | 28 | 2 | $r_{1} \cdot r_{2}$ | $r_{1}, r_{2}$ |
| LE | Load, Short | 78 | 4 | $r_{1}, d_{2}\left(x_{2}, b_{2}\right)$ | $r_{1}, s_{2}\left(x_{2}\right)$ |
| LER | Load, Short | 38 | 2 | $r_{1}, r_{2}$ | $r_{1} r_{2}$ |
| LH | Load Half Word | 48 | 4 | $r_{1}, d_{2}\left(x_{2}, b_{2}\right)$ | $r_{1}, s_{2}\left(x_{2}\right)$ |
| LM | Load Multiple | 98 | 4 | $r_{1}, r_{3}, d_{2}\left(b_{2}\right)$ | $r_{1}, r_{3}, s_{2}$ |
| LNDR | Load Negative, Long | 21 | 2 | $r_{1} \cdot r_{2}$ | $r_{1}, r_{2}$ |
| LNER | Load Negative, Short | 31 | 2 | $r_{1}, r_{2}$ | $r_{1} r_{2}$ |
| LNR | Load Negative | 11 | 2 | $r_{1} \cdot r_{2}$ | $r_{1}, r_{2}$ |
| LPDR | Load Positive, Long | 20 | 2 | $r_{1}, r_{2}$ | $r_{1}, r_{2}$ |
| LPER | Load Positive, Short | 30 | 2 | $r_{1}, r_{2}$ | $r_{1}, r_{2}$ |
| LPR | Load Positive | 10 | 2 | $r_{1}, r_{2}$ | $r_{1}, r_{2}$ |
| LPSW | Load Program Status Word | 82 | 4 | (Privileged) | (Privileged) |
| LR | Load | 18 | 2 | $\mathrm{r}_{1}, \mathrm{r}_{2}$ | $r_{1}, r_{2}$ |
| LTDR | Load and Test, Long | 22 | 2 | $r_{1}, r_{2}$ | $r_{1}, r_{2}$ |
| LTER | Load and Test, Short | 32 | 2 | $r_{1}, r_{2}$ | $r_{1}, r_{2}$ |
| LTR | Load and Test | 12 | 2 | $\mathrm{r}_{1}, \mathrm{r}_{2}$ | $r_{1}, r_{2}$ |
| M | Multiply | 5C | 4 | $r_{1}, c_{2}\left(x_{2}, b_{2}\right)$ | $r_{1}, s_{2}\left(x_{2}\right)$ |
| MD | Multiply, Long | 6C | 4 | $r_{1}, d_{2}\left(x_{2}, b_{2}\right)$ | $r_{1}, s_{2}\left(x_{2}\right)$ |
| MDR | Multiply, Long | 2C | 2 | $r_{1} \cdot r_{2}$ | $r_{1}, r_{2}$ |

Table E-1. Mnemonic List of Instructions (Part 3 of 4)

| Mnemonic | Instruction Name | Machine Code | Byte <br> Length | Source Code Format |  |
| :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  |  | Explicit | Implicit |
| ME | Multiply, Short | 7 C | 4 | $\mathrm{r}_{1}, \mathrm{~d}_{2}\left(\mathrm{x}_{2}, \mathrm{~b}_{2}\right)$ | $r_{1}, s_{2}\left(x_{2}\right)$ |
| MER | Multiply, Short | 3 C | 2 | $\mathrm{r}_{1}, \mathrm{r}_{2}$ | $\mathrm{r}_{1}, \mathrm{r}_{2}$ |
| MH | Multiply Half Word | 4 C | 4 | $r_{1}, d_{2}\left(x_{2}, b_{2}\right)$ | $r_{1}, s_{2}\left(x_{2}\right)$ |
| MP | Multiple Decimal | FC | 6 | $d_{1}\left(l_{1}, b_{1}\right), d_{2}\left(l_{2}, b_{2}\right)$ | $\mathrm{s}_{1}(1)_{1}$, $\mathrm{s}_{2}\left(\mathrm{l}_{2}\right)$ |
| MR | Multiply | 1 C | 2 | $\mathrm{r}_{1}, \mathrm{r}_{2}$ | $r_{1}, r_{2}$ |
| MVC | Move Characters | D2 | 6 | $d_{1}\left(1, b_{1}\right), d_{2}\left(b_{2}\right)$ | $\mathrm{s}_{1}(1), \mathrm{s}_{2}$ |
| MVI | Move Immediate | 92 | 4 | $d_{1}\left(b_{1}\right), i_{2}$ | $\mathrm{s}_{1}, \mathrm{i}_{2}$ |
| MVN | Move Numerics | D1 | 6 | $d_{1}\left(1, b_{1}\right), d_{2}\left(b_{2}\right)$ | $\mathrm{s}_{1}(1), s_{2}$ |
| MVO | Move With Offset | F1 | 6 | $d_{1}\left(l_{1}, b_{1}\right), d_{2}\left(l_{2}, b_{2}\right)$ | $s_{1}\left(1 l_{1}\right), s_{2}\left(l_{2}\right)$ |
| MVZ | Move Zones | D3 | 6 | $d_{1}\left(1, b_{1}\right), d_{2}\left(b_{2}\right)$ | $\mathrm{s}_{1}(1) \mathrm{s}_{2}$ |
| N | AND Logical | 54 | 4 | $r_{1}, d_{2}\left(x_{2}, b_{2}\right)$ | $\mathrm{r}_{1}, s_{2}\left(\mathrm{x}_{2}\right)$ |
| NC | AND Logical | D4 | 6 | $d_{1}\left(1, b_{1}\right), d_{2}\left(b_{2}\right)$ | $\mathrm{s}_{1}(1), \mathrm{s}_{2}$ |
| NI | AND Logical Immediate | 94 | 4 | $d_{1}\left(b_{1}\right) i_{2}$ | $\mathrm{s}_{1}, \mathrm{i}_{2}$ |
| NR | AND Logical | 14 | 2 | $\mathrm{r}_{1}, r_{2}$ | $\mathrm{r}_{1}, \mathrm{r}_{2}$ |
| 0 | OR Logical | 56 | 4 | $\mathrm{r}_{1}, \mathrm{~d}_{2}\left(\mathrm{x}_{2}, \mathrm{~b}_{2}\right)$ | $r_{1}, s_{2}\left(x_{2}\right)$ |
| OC | OR Logical | D6 | 6 | $d_{1}\left(1, b_{1}\right), d_{2}\left(b_{2}\right)$ | $\mathrm{s}_{1}(1), s_{2}$ |
| OI | OR Logical Immediate | 96 | 4 | $\mathrm{d}_{1}\left(\mathrm{~b}_{1}\right), \mathrm{i}_{2}$ | $\mathrm{s}_{1}, \mathrm{i}_{2}$ |
| OR | OR Logical | 16 | 2 | $\mathrm{r}_{1}, \mathrm{r}_{2}$ | $\mathrm{r}_{1}, r_{2}$ |
| PACK | Pack | F2 | 6 | $d_{1}\left(l_{1}, b_{1}\right), d_{2}\left(l_{2}, b_{2}\right)$ | $s_{1}\left(I_{1}\right), s_{2}\left(I_{2}\right)$ |
| S | Subtract | 5B | 4 | $r_{1}, d_{2}\left(x_{2}, b_{2}\right)$ | $r_{1}, s_{2}\left(x_{2}\right)$ |
| SD | Subtract Normalized, Long | 6B | 4 | $r_{1}, d_{2}\left(x_{2}, b_{2}\right)$ | $r_{1}, s_{2}\left(x_{2}\right)$ |
| SDR | Subtract Normalized, Long | 2B | 2 | $\mathrm{r}_{1}, r_{2}$ | $\mathrm{r}_{1}, \mathrm{r}_{2}$ |
| SE | Subtract Normalized, Short | 78 | 4 | $r_{1}, d_{2}\left(x_{2}, b_{2}\right)$ | $r_{1}, s_{2}\left(x_{2}\right)$ |
| SER | Subtract Normalized, Short | 3B | 2 | $r_{1}, r_{2}$ | ${ }_{1} r_{1} r_{2}$ |
| SH | Subtract Half Word | 4B | 4 | $r_{1}, d_{2}\left(x_{2}, b_{2}\right)$ | $r_{1}, s_{2}\left(x_{2}\right)$ |
| SIO | Start 1/0 | 9C | 4 | (Privileged) | (Privileged) |
| SL | Subtract Logical | 5F | 4 | $\mathrm{r}_{1}, d_{2}\left(\mathrm{x}_{2}, \mathrm{~b}_{2}\right)$ | $r_{1}, s_{2}\left(x_{2}\right)$ |
| SLA | Shift Left Single Algebraic | 8B | 4 | $\mathrm{r}_{1}, \mathrm{~d}_{2}\left(\mathrm{~b}_{2}\right)$ | $\mathrm{r}_{1}, \mathrm{~s}_{2}$ |
| SLDA | Shift Left Double Algebraic | 8F | 4 | $\mathrm{r}_{1}, \mathrm{~d}_{2}\left(\mathrm{~b}_{2}\right)$ | $r_{1}, s_{2}$ |
| SLDL | Shift Left Double Logical | 8D | 4 | $\mathrm{r}_{1}, \mathrm{~d}_{2}\left(\mathrm{~b}_{2}\right)$ | ${ }_{1}{ }_{1} s_{2}$ |
| SLL | Shift Left Single Logical | 89 | 4 | $\mathrm{r}_{1}, \mathrm{~d}_{2}\left(\mathrm{~b}_{2}\right)$ | $\mathrm{r}_{1}, s_{2}$ |
| SLM | Supervisor Load Multiple | B8 | 4 | (Privileged) | (Privileged) |
| SLR | Subtract Logical | 1F | 2 | $\mathrm{r}_{1} \mathrm{r}_{2}$ | $r_{1}, r_{2}$ |
| SP | Subtract Decimal | FB | 6 | $d_{1}\left(l_{1}, b_{1}\right), d_{2}\left(l_{2}, b_{2}\right)$ | $\mathrm{s}_{1}\left(I_{1}\right), s_{2}\left(I_{2}\right)$ |
| SPM | Set Program Mask | 04 | 2 | $\mathrm{r}_{1}$ |  |
| SR | Subtract | 1B | 2 | $r_{1}, r_{2}$ | $r_{1}, r_{2}$ |
| SRA | Shift Right Single Algebraic | 8A | 4 | $\mathrm{r}_{1}, \mathrm{~d}_{2}\left(\mathrm{~b}_{2}\right)$ | $r_{1}, s_{2}$ |
| SRDA | Shift Right Double Algebraic | 8E | 4 | $\mathrm{r}_{1}, \mathrm{~d}_{2}\left(\mathrm{~b}_{2}\right)$ | $\mathrm{r}_{1}, s_{2}$ |
| SRDL | Shift Right Double Logical | 8C | 4 | $\mathrm{r}_{1}, \mathrm{~d}_{2}\left(\mathrm{~b}_{2}\right)$ | $r_{1}, s_{2}$ |
| SRL | Shift Right Single Logical | 88 | 4 | $\mathrm{r}_{1}, \mathrm{~d}_{2}\left(\mathrm{~b}_{2}\right)$ | $\mathrm{r}_{1}, s_{2}$ |
| 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 | B0 | 4 | (Privileged) | (Privileged) |
| ST | Store | 50 | 4 | $\mathrm{r}_{1}, \mathrm{~d}_{2}\left(\mathrm{x}_{2}, \mathrm{~b}_{2}\right)$ | $r_{1}, s_{2}\left(x_{2}\right)$ |
| STC | Store Character | 42 | 4 | $\mathrm{r}_{1}, \mathrm{~d}_{2}\left(\mathrm{x}_{2}, \mathrm{~b}_{2}\right)$ | $r_{1}, s_{2}\left(x_{2}\right)$ |
| STD | Store Long | 60 | 4 | $\mathrm{r}_{1}, \mathrm{~d}_{2}\left(\mathrm{x}_{2}, \mathrm{~b}_{2}\right)$ | $r_{1}, s_{2}\left(x_{2}\right)$ |

Table E-1. Mnemonic List of Instructions (Part 4 of 4)

| Mnemonic | Instruction Name | Machine Code | Byte <br> Length | Source Code Format |  |
| :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  |  | Explicit | Implicit |
| STE | Store Short | 70 | 4 | $\mathrm{r}_{1}, \mathrm{~d}_{2}\left(\mathrm{x}_{2}, \mathrm{~b}_{2}\right)$ | $r_{1}, s_{2}\left(x_{2}\right)$ |
| STH | Store Half Word | 40 | 4 | $r_{1}, d_{2}\left(x_{2}, b_{2}\right)$ | $r_{1}, s_{2}\left(x_{2}\right)$ |
| STM | Store Multiple | 90 | 4 | $r_{1}, r_{3}, d_{2}\left(b_{2}\right)$ |  |
| STR | Service Timer Register | 03 | 2 | (Privileged) | (Privileged) |
| SU | Subtract Unnormalized, Short | 7F | 4 | $r_{1}, d_{2}\left(x_{2}, b_{2}\right)$ | $r_{1}, s_{2}\left(x_{2}\right)$ |
| SUR | Subtract Unnormalized, Short | 3F | 2 | $r_{1} r_{2}$ | $r_{1}, r_{2}$ |
| SVC | Supervisor Call | OA | 2 |  |  |
| SW | Subtract Unnormalized, Long | 6F | 4 | $r_{1}, d_{2}\left(x_{2}, b_{2}\right)$ | $r_{1}, s_{2}\left(x_{2}\right)$ |
| SWR | Subtract Unnormalized, Long | 2F | 2 | $r_{1}, r_{2}$ | $r_{1}, r_{2}$ |
| TM | Test Under Mask | 91 | 4 | $d_{1}\left(b_{1}\right), i_{2}$ | $\mathrm{s}_{1}, \mathrm{i}_{2}$ |
| TR | Translate | DC | 6 | $d_{1}\left(1, b_{1}\right), d_{2}\left(b_{2}\right)$ | $s_{1}(1), s_{2}$ |
| TRT | Translate and Test | DD | 6 | $d_{1}\left(1, b_{1}\right), d_{2}\left(b_{2}\right)$ | $s_{1}(1), s_{2}$ |
| TS | Test and Set | 93 | 4 | $d_{1}\left(b_{1}\right)$ |  |
| UNPK | Unpack | F3 | 6 | $d_{1}\left(11_{1}, b_{1}\right), d_{2}\left(l_{2}, b_{2}\right)$ | $s_{1}\left(11_{1}\right) s_{2}\left(1{ }_{2}\right)$ |
| X | Exclusive OR | 57 | 4 | $r_{1}, d_{2}\left(x_{2}, b_{2}\right)$ | $r_{1}, s_{2}\left(x_{2}\right)$ |
| XC | Exclusive OR | D7 | 6 | $d_{1}\left(1, b_{1}\right), d_{2}\left(b_{2}\right)$ | $s_{1}(1), s_{2}$ |
| XI | Exclusive OR, Immediate | 97 | 4 | $d_{1}\left(b_{1}\right), i_{2}$ | $\mathrm{s}_{1}, \mathrm{i}_{2}$ |
| XR | Exclusive OR | 17 | 2 | $\mathrm{r}_{1}, \mathrm{r}_{2}$ | $r_{1}, r_{2}$ |
| ZAP | Zero and Add Decimal | F8 | 6 | $d_{1}\left(1, b_{1}\right), d_{2}\left(l_{2}, b_{2}\right)$ | $s_{1}\left(1 I_{1}\right) s_{2}\left(l_{2}\right)$ |

Table E-2. Alphabetic Listing of Instructions (Part 1 of 6)

| Instruction Name |  | Machine | Mnemonic |
| :---: | :---: | :---: | :---: |
| Add | (Native and 360/20 modes) | 1 A | AR* |
| Add |  | 5 A | A |
| Add Decimal |  | FA | AP* |
| Add Half Word | (Native and 360/20 modes) | 4A | AH* |
| Add Half Word | (9200/9300 mode only) | AA $\dagger$ | $A H^{*}$ |
| Add Immediate |  | 9 A | Al |
| Add Immediate | (9200/9300 mode only) | A6t | Al* |
| Add Logical |  | 1 E | ALR** |
| Add Logical |  | 5E | AL** |
| Add Normalized, Long |  | 2 A | ADR** |
| Add Normalized, Long |  | 6 A | $A D^{* *}$ |
| Add Normalized, Short |  | 3A | AER** |
| Add Normalized, Short |  | 7A | $A E^{* *}$ |
| Add Unnormalized, Long |  | 2 E | AWR** |
| Add Unnormalized, Long |  | 6 E | AW** |
| Add Unnormalized, Short |  | 3E | AUR** |
| Add Unnormalized, Short |  | 7E | $A U^{* *}$ |
| AND |  | 14 | NR |
| AND |  | 54 | $N$ |
| AND |  | 94 | N ${ }^{*}$ |
| AND | (Native and 9200/9300 modes) | D4 | NC* |
| Branch and Link |  | 05 | BALR |
| Branch and Link | (Native and 9200/9300 modes) | 45 | BAL* |
| Branch and Store | (360/20 mode only) | 4D | BAS* |
| Branch and Store | (360/20 mode only) | OD | BASR* |
| Branch on Condition | (Native and 360/20 modes) | 07 | BCR * |
| Branch on Condition |  | 47 | BC* |
| Branch on Count |  | 06 | BCTR |
| Branch on Count |  | 46 | BCT |
| Branch on Index High |  | 86 | BXH** |
| Branch on Index Low or Equal |  | 87 | BXLE** |

Table E-2. Alphabetic Listing of Instructions (Part 2 of 6)

| Instruction Name | Machine Code | Mnemonic |
| :---: | :---: | :---: |
| Compare | 19 | CR |
| Compare | 59 | C |
| Compare Decimal | F9 | CP* |
| Compare Half Word | 49 | $\mathrm{CH}^{*}$ |
| Compare Logical | 15 | CLR |
| Compare Logical | 55 | CL |
| Compare Logical | 95 | CLI* |
| Compare Logical | D5 | CLC* |
| Compare, Long | 29 | CDR** |
| Compare, Long | 69 | CD** |
| Compare, Short | 39 | CER** |
| Compare, Short | 79 | CE** |
| Convert to Binary | 4F | CVB |
| Convert to Decimal | 4E | CVD |
| Diagnose - Privileged | 83 | DIAG |
| Divide | 1D | DR** |
| Divide | 5D | D |
| Divide Decimal | FD | (C)DP |
| Divide, Long | 2D | DDR** |
| Divide, Long | 6D | DD** |
| Divide, Short | 30 | DER** |
| Divide, Short | 70 | DE** |
| Edit | DE | ED* |
| Edit and Mark | DF | EDMK** |
| Exclusive OR | 17 | XR |
| Exclusive OR | 57 | x |
| Exclusive OR | 97 | XI |
| Exclusive OR | D7 | xc |
| Execute | 44 | EX |

Table E-2. Alphabetic Listing of Instructions (Part 3 of 6)

| Instruction Name | Machine Code | Mnemonic |
| :---: | :---: | :---: |
| Halt and Proceed - Privileged | 99 | HPR |
| Halve, Long | 24 | HDR** |
| Halve, Short | 34 | HER** |
| Insert Character | 43 | IC |
| Insert Storage Key - Privileged | 09 | ISK** |
| Load | 18 | LR |
| Load | 58 | L |
| Load Address | 41 | LA |
| Load and Test | 12 | LTR |
| Load and Test, Long | 22 | LTDR** |
| Load and Test, Short | 32 | LTER** |
| Load Complement | 13 | LCR** |
| Load Complement, Long | 23 | LCDR** |
| Load Complement, Short | 33 | LCER** |
| Load Control Storage - Privileged | B1 | LCS |
| Load Half Word | 48 | LH* |
| Load, Long | 28 | LDR** |
| Load. Long | 68 | LD** |
| Load Multiple | 98 | LM |
| Load Negative | 11 | LNR** |
| Load Negative, Long | 21 | LNDR** |
| Load Negative, Short | 31 | LNER** |
| Load Positive | 10 | LPR** |
| Load Positive, Long | 20 | LPDR** |
| Load Positive, Short | 30 | LPER** |
| Load PSW - Privileged | 82 | LPSW |
| Load, Short | 38 | LER** |
| Load, Short | 78 | LE** |

Table E-2. Alphabetic Listing of Instructions (Part 4 of 6)

| Instruction Name | Machine | Mnemonic |
| :---: | :---: | :---: |
| Move | 92 | MVI* |
| Move | D2 | MVC* |
| Move Numerics | D1 | MVN* |
| Move With Offset | F1 | MVO* |
| Move Zones (Native and 360/20 modes) | D3 | MVZ* |
| Multiply | 1 C | MR** |
| Multiply | 5 C | M |
| Multiply Decimal | FC | MP* |
| Multiply Half Word | 4 C | M ${ }^{* *}$ |
| Multiply, Long | 2 C | MDR** |
| Multiply, Long | 6 C | M ${ }^{* *}$ |
| Multiply, Short | 3 C | MER** |
| Multiply, Short | 7 C | ME** |
| OR | 16 | OR |
| OR | 56 | 0 |
| OR | 96 | O1* |
| OR (Native and 9200/9300 modes) | D6 | OC* |
| Pack | F2 | PACK* |
| Service Timer Register - Privileged | 03 | STR |
| Set Program Mask | 04 | SPM |
| Set Storage Key - Privileged | 08 | SSK** |
| Set System Mask - Privileged | 80 | SSM |
| Shift Left Double | 8 F | SLDA** |
| Shift Left Double Logical | 8D | SLDL** |
| Shift Left Single | 8B | SLA** |
| Shift Left Single Logical | 89 | SLL |
| Shift Right Double | 8E | SRDA** |
| Shift Right Double Logical | 8 C | SRDL** |
| Shift Right Single | 8A | SRA** |
| Shift Right Single Logical | 88 | SRL |

Table E-2. Alphabetic Listing of Instructions (Part 5 of 6)

| Instruction Name | Machine Code | Mnemonic |
| :---: | :---: | :---: |
| SOFTSCOPE Forward Scan - Privileged | A2 | SSFS |
| SOFTSCOPE Reverse Scan - Privileged | A3 | SSRS |
| Start I/O - Privileged | 9 C | SIO |
| Store | 50 | ST |
| Store Character | 42 | STC |
| Store Half Word | 40 | STH* |
| Store, Long | 60 | STD** |
| Store Multiple | 90 | STM |
| Store, Short | 70 | STE** |
| Subtract (Native and 360/20 modes) | 1B | SR* |
| Subtract | 5B | S |
| Subtract Decimal | FB | SP* |
| Subtract Half Word (Native and 360/20 modes) | 4B | SH* |
| Subtract Half Word (9200/9300 mode only) | $A B$ | SH* |
| Subtract Logical | 1F | SLR** |
| Subtract Logical | 5 F | SL** |
| Subtract Normalized, Long | 2B | SDR** |
| Subtract Normalized, Long | 6B | SD** |
| Subtract Normalized, Short | 3B | SER** |
| Subtract Normalized, Short | 78 | SE** |
| Subtract Unnormalized, Long | 2 F | SWR** |
| Subtract Unnormalized, Long | 6 F | SW** |
| Subtract Unnormalized, Short | $3 F$ | SUR** |
| Subtract Unnormalized, Short | 7F | SU** |
| Supervisor Call | OA | SVC |
| Supervisor Load Multiple - Privileged | B8 | SLM |
| Supervisor Store Multiple - Privileged | BO | SSTM |

Table E-2. Alphabetic Listing of Instructions (Part 6 of 6)

| Instruction Name | Machine <br> Code | Mnemonic |
| :--- | :---: | :---: |
| Test and Set | 93 | TS $^{* *}$ |
| Test Under Mask | 91 | TM $^{*}$ |
| Translate | DC | TR* |
| Translate and Test | DD | TRT |
| Unpack | F3 | UNPK* |
| Zero and Add | F8 | ZAP* |

NOTE:
Unless otherwise indicated, mnemonic instructions are available in native mode only.
*Available in native mode and 9200/9300 and 360/20 compatibility modes except as noted.
**Added as a feature.
$\dagger$ Executes machine code in 9200/9300 compatibility mode only.

Table E-3. List of Instructions by Machine Code (Part 1 of 6)

| 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 | BCR* | Branch on Condition (Native and 360/20 modes) |
| 08 | SSK** | Set Storage Key - Privileged |
| 09 | ISK** | Insert Storage Key - Privileged |
| 0 OA | SVC | Supervisor Call |
| 10 | LPR** | Branch and Store (360/20 mode only) |
| 11 | LNR** | Load Positive |
| 12 | LTR | Load Negative |

Table E-3. List of Instructions by Machine Code (Part 2 of 6)

| Machine Code | Mnemonic | Instruction Name |
| :---: | :---: | :---: |
| 13 | LCR** | Load Complement |
| 14 | NR | AND |
| 15 | CLR | Compare Logical |
| 16 | OR | OR |
| 17 | XR | Exclusive OR |
| 18 | LR | Load |
| 19 | CR | Compare |
| 1A | AR* | Add (Native and 360/20 modes) |
| 1 B | SR* | Subtract (Native and 360/20 modes) |
| 1 C | MR** | Multioly |
| 10 | DR** | Divide |
| 1E | ALR** | Add Logical |
| 1F | SLR** | Subtract Logical |
| 20 | LPDR** | Load Positive, Long |
| 21 | LNDR** | Load Negative, Long |
| 22 | LTDR** | Load And Test, Long |
| 23 | LCDR** | Load Complement, Long |
| 24 | HDR** | Halve, Long |
| 28 | LDR** | Load, Long |
| 29 | CDR** | Compare, Long |
| 2A | ADR** | Add Normalized, Long |
| 2B | SDR** | Subtract Normalized, Long |
| 2 C | MDR** | Multiply, Long |
| 2D | DDR** | Divide, Long |
| 2E | AWR** | Add Unnormalized, Long |
| 2F | SWR** | Subtract Unnormalized, Long |
| 30 | LPER** | Load Positive, Short |
| 31 | LNER** | Load Negative, Short |
| 32 | LTER** | Load And Test, Short |

Table E-3. List of Instructions by Machine Code (Part 3 of 6)

| Machine Code | Mnemonic | Instruction Name |
| :---: | :---: | :---: |
| 33 | LCER** | Load Complement. Short |
| 34 | HER** | Halve, Short |
| 38 | LER** | Load, Short |
| 39 | CER** | Compare, Short |
| 3A | AER** | Add Normalized, Short |
| 3 B | SER** | Subtract Normalized, Short |
| 3 C | MER** | Multiply, Short |
| 3D | DER** | Divide, Short |
| 3E | AUR** | Add Unnormalized, Short |
| 3F | SUR** | Subtract Unnormalized, Short |
| 40 | STH* | Store Half Word |
| 41 | LA | Load Address |
| 42 | STC | Store Character |
| 43 | IC | Insert Character |
| 44 | EX | Execute |
| 45 | BAL* | Branch and Link (Native and 9200/9300 modes) |
| 46 | BCT | Branch on Count |
| 47 | BC* | Branch on Condition |
| 48 | LH* | Load Half Word |
| 49 | $\mathrm{CH}^{*}$ | Compare Half Word |
| 4A | AH* | Add Half Word (Native and 360/20 modes) |
| 4B | SH* | Subtract Half Word (Native and 360/20 modes) |
| 4 C | M ${ }^{* *}$ | Multiply Half Word |
| 4D | 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 |

Table E-3. List of Instructions by Machine Code (Part 4 of 6)

| Machine Code | Mnemonic | Instruction Name |
| :---: | :---: | :---: |
| 56 | 0 | OR |
| 57 | x | Exclusive OR |
| 58 | L | Load |
| 59 | c | Compare |
| 5A | A | Add |
| 5B | S | Subtract |
| 5 C | M | Multiply |
| 5D | D | Divide |
| 5E | AL** | Add Logical |
| 5F | SL** | Subtract Logical |
| 60 | STD** | Store, Long |
| 68 | LD** | Load, Long |
| 69 | $C D^{* *}$ | Compare, Long |
| 6A | AD** | Add Normalized, Long |
| 6 B | SD** | Subtract Normalized, Long |
| 6 C | MD** | Multiply, Long |
| 6 D | DD** | Divide, Long |
| 6 E | AW** | Add Unnormalized, Long |
| 6 F | sW** | Subtract Unnormalized, Long |
| 70 | STE** | Store, Short |
| 78 | LE** | Load, Short |
| 79 | CE** | Compare, Short |
| 7A | AE** | Add Normalized, Short |
| 7 B | SE** | Subtract Normalized, Short |
| 7 C | ME** | Multiply, Short |
| 7 D | DE** | Divide, Short |
| 7 E | AU** | Add Unnormalized, Short |
| 7 F | SU** | Subtract Unnormalized. Short |
| 80 | SSM | Set System Mask - Privileged |
| 82 | LPSW | Load PSW - Privileged |

Table E-3. List of Instructions by Machine Code (Part 5 of 6)

| Machine Code | Mnemonic | Instruction Name |
| :---: | :---: | :---: |
| 83 | DIAG | Diagnose - Privileged |
| 86 | BXH** | Branch on Index High |
| 87 | BXLE** | Branch on Index Low or Equal |
| 88 | SRL | Shift Right Single Logical |
| 89 | SLL | Shift Left Single Logical |
| 8A | SRA** | Shift Right Single |
| 8 B | SLA** | Shift Left Single |
| 8 C | SRDL** | Shift Right Double Logical |
| 80 | SLDL** | Shift Left Double Logical |
| 8E | SRDA** | Shift Right Double |
| 8F | SLDA** | Shift Left Double |
| 90 | STM | Store Multiple |
| 91 | TM* | Test Under Mask |
| 92 | MVI* | Move Immediate |
| 93 | TS** | Test and Set |
| 94 | N ${ }^{*}$ | AND |
| 95 | CLI* | Compare Logical |
| 96 | O1* | OR |
| 97 | XI | Exclusive OR |
| 98 | LM | Load Multiple |
| 99 | HPR | Halt and Proceed - Privileged |
| 9A | Al | Add Immediate |
| 9 C | SIO | Start I/O - Privileged |
| A2 | SSFS | SOFTSCOPE Forward Scan - Privileged |
| A3 | SSRS | SOFTSCOPE Reverse Scan - Privileged |
| A6 $\dagger$ | AI* | Add Immediate (9200/9300 mode only) |
| AAt | $\mathrm{AH}^{*}$ | Add Half Word (9200/9300 mode only) |
| AB $\dagger$ | SH* | Subtract Half Word (9200/9300 mode only) |
| B0 | SSTM | Supervisor Store Multiple - Privileged |
| B1 | LCS | Load Control Storage - Privileged |

Table E-3. List of Instructions by Machine Code (Part 6 of 6)

| Machine Code | Mnemonic | Instruction Name |
| :---: | :---: | :---: |
| B8 | SLM | Supervisor Load Multiple - Privileged |
| D1 | MVN* | Move Numerics |
| D2 | MVC* | Move |
| D3 | MVZ* | Move Zones (Native and 360/20 modes) |
| D4 | NC* | AND (Native and 9200/9300 modes) |
| D5 | CLC* | Compare Logical |
| D6 | OC* | OR (Native and 9200/9300 modes) |
| D7 | xc | Exclusive OR |
| DC | TR* | Translate |
| DD | TRT | Translate and Test |
| DE | ED* | Edit |
| DF | EDMK** | Edit and Mark |
| F1 | MVO* | Move With Offset |
| F2 | PACK* | Pack |
| F3 | UNPK* | Unpack |
| F8 | ZAP* | Zero and Add |
| F9 | CP* | Compare Decimal |
| FA | AP* | Add Decimal |
| FB | SP* | Subtract Decimal |
| FC | MP* | Multiply Decimal |
| FD | DP* | Divide Decimal |

NOTE:
Unless otherwise indicated, mnemonic instructions are available in native mode only.
*Available in native mode and 9200/9300 and 360/20 compatibility modes except as noted.
**Added as a feature.
$\dagger$ Executes machine code in 9200/9300 compatibility mode only.

## Appendix F. Use of PARAM Statement

This appendix describes the use of the PARAM statement and the option-specifying operands supported by the SPERRY UNIVAC Operating System/3 (OS/3) Assembler. These options permit you to identify library files, to access source or copy modules and macro definitions from these libraries, to select assembler listings, and to control object module output. Also included in this appendix is the source module correction routine.

## F.1. PARAM STATEMENT

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 (\$YSRUN).
- It prints the soruce code, object code, cross-references, and diagnostic listings.
- The value of $\&$ SYSPARM is equal to a null string.
- Columns 1 and 2 of the coding form must contain slashes, followed by at least one blank column, and then PARAM followed by at least one blank column (see following page). Multiple options are supported for each option separated by commas. The end of selected options is indicated by a blank column following the last option. All options selected are printed preceding the assembly listing.


## Format:

| 1 | 10 |
| :---: | :---: |
| $/ / \triangle$ PARAM $\triangle$ | $\left[\right.$ COPY $\left.\left.=\left\{\begin{array}{c}\text { filename1 } \\ (\mathbf{N}) \\ \text { SYSSRC }\end{array}\right\}\left[1 \begin{array}{c}\text { filename2 } \\ (\mathbf{N}) \\ \text { SYSSRC }\end{array}\right\}\right]\right]$ |
|  | $\left[, I N=\text { modulename }\left[/\left\{\begin{array}{l} \text { filename } \\ \text { SYSSRC } \end{array}\right\}\right]\right]$ |
|  | $\left[, \text { LIN }=\left\{\begin{array}{c} \text { filename } 1 \\ (\mathbf{N}) \\ \text { SYSMAC } \end{array}\right\}\left[/\left\{\begin{array}{c} \text { filename2 } \\ (\mathbf{N}) \\ \text { SYSMAC } \end{array}\right\}\right]\right]$ |
|  | $[, L S T=\{([[s 1][, s 2][, s 3][, s 4])\}]$ |
|  | $\left[\text { OUT }=\left\{\begin{array}{c} \text { filename } \\ (N) \\ \text { SYSRUN } \end{array}\right\}\right]$ |
|  | $\left[, R 0=\left\{\begin{array}{l} \text { YES } \\ \text { re } \end{array}\right\}\right]$ |
|  | $\left[, S Y S P A R M=\left\{\begin{array}{l}\text { 'string' } \\ \text { null-string }\end{array}\right\}\right]$ |

## COPY Keyword Parameter:

Enables up to two files to be 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 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.

COPY=filename1
Specifies that the file identified as filename1 is searched first for source code modules referenced and, if not found there, then $\$ Y \$ S R C$ is searched: filename is any name you specify or the system source library. If filename $1=$ filename2, then copy $=$ filename1 will generate the same files to be searched as copy $=$ /filename2, except that in the first case the order in which the files are to be searched will be filename1 and then \$Y\$SRC, whereas in the second case, the order will be $\$ \mathbf{Y} \$ \mathrm{SRC}$ and then filename2.

## COPY=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 SYSSRC file is not searched.

COPY=filename1/(N)
Specifies only the file identified as filename1 is searched for source code modules referenced. As stated previously, if filename1 $=$ filename2, then copy $=$ filename $1 /(N)$ is the same as copy $=(N) /$ filename 2 , with only one file to be searched in either case.

## COPY=(N)

Specifies no files, not even $\$ Y \$ S R C$, are searched for source code modules referenced. $\operatorname{COPY}=(N) /(N)$ is the same as $\operatorname{COPY}=(N)$.

IN Keyword Parameter:
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.

## IN=modulename

Specifies the name of the source module and directs the assembler to search the $\$ Y \$ S R C$ file for the module; modulename is the name of the source module and is up to eight characters.

## IN=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 Keyword Parameter:
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.

LIN=filename1
Identifies the file that is searched for macro references and, if not found there, then $\$ Y \$ M A C$ is searched; filename is any name or the name of the system macro library.

## LIN=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 filename2. The \$Y\$MAC file is not searched.

## LIN=filename1/(N)

Specifies only the file identified as filename1 is searched for macro references.
$\operatorname{LIN}=(\mathbf{N})$
Specifies no files, not even $\$$ Y $\$$ MAC, are searched for macro references.

## LST Keyword Parameter:

Indicates the type of listing desired. If this option is omitted, source, object, crossreference, and diagnostic listings are printed.

LST=s
A single specification requiring no parentheses.
LST $=\left(\left[\mathbf{s}_{1}\right] \ldots\left[\mathbf{s}_{4}\right]\right)$
Any $s$ in the series is one of the following:

## NC

Specifies that the cross-reference listing is suppressed.
ND
Specifies that the diagnostic listing is suppressed.
NR
Specifies that the cross reference listing is to contain only those symbols that have at least one reference each.

N
Specifies that all output listings are suppressed.
DBG
Specifies a proc or macro debug mode feature within the $\mathrm{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.
- All lines flagged (regardless of their order of 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 Keyword Parameter:

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.

## OUT=filename

Identifies the file that is used as the output file by the assembler; filename is any name or the job run library.

OUT=(N)
Specifies that no output file is used by the assembler and, thus, no object module is generated.

RO Keyword Parameter:
Permits you to optionally flag all absolute/base displacement fields of instructions that yield values less than 4096. Each statement is flagged with an 'ADDRESSABILITY' error flag. For example, if you wanted to code MVI TAG, $X^{\prime} 40$ ' but coded MVC TAG, $\mathrm{X}^{\prime} 40^{\prime}$ by mistake, the latter instruction would be flagged, since the displacement field is less than 4096.

## SYSPARM Keyword Parameter:

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.

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.

## SYSPARM='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.

## F.2. SOURCE CORRECTIONS

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 that 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 (// $\triangle$ PARAM $\triangle I N=$ modulename or the $\mathrm{IN}=($ vol-ser-no,label) for the jproc call) and the correction records in the job control stream. These records must be with 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.

## F.2.1. SEQ Statement

Function:
Specifies the starting position and the length of the sequence field. If the sequence file is omitted, column 73 is assumed to be the first column of the sequence field and continues to the maximum of eight characters.

## Format:

| LABEL | $\triangle$ OPERATION $\Delta$ | OPERAND |
| :---: | :---: | :---: |
| unused | SEQ | $\ldots\left\{\begin{array}{c}\text { column position } \\ 73\end{array}\right\},\left\{\begin{array}{c}\text { content } \\ 00000000\end{array}\right\}$ |

Specifications:
column position
Is 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
Is one to eight characters. The length determines the length of the sequence field.
Operational Considerations:

- Card column 1 must be blank if the sequence field does not start in card column 1.
- The SEQ card is always the first card in the correction routine.


## F.2.2. REC Statement

Function:
Causes the record pointer for the input module to be repositioned to the first record in the module. In conjunction with the SKI control statement, it allows the 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 second 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:


## Specification:

## last sequence no.

Is one to eight alphanumeric characters that identify the sequence number of the last input record to be read from the input module. If omitted, the repositioning function takes place immediately.

Operational Considerations:

- 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.


## F.2.3. SKI Statement

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 | $\triangle$ OPERATION $\Delta$ | OPERAND |  |
| :---: | :--- | :--- | :--- |
| ignored | SKI | [last-sequence no.] | [starting-sequente no.] |

Specifications:
last-sequence-no.
Is one to eight alphanumeric characters that identify the sequence number of the last input module record to be bypassed.
starting-sequence-no.
Is one to eight alphanumeric characters that identify the sequence number of the first source module record to be bypassed.

Operational Consideration:

- If omitted, the skip operation starts immediately with the input module record that follows the last record operated on.


## Appendix G. System Variable Symbols

System variable symbols automatically generate values or character strings at assembly time. There are seven system variable symbols: \&SYSECT, \&SYSLIST, \&SYSNDX, \&SYSDATE, \&SYSTIME, \&SYSJDATE, and \&SYSPARM. The following paragraphs contain the functions of each of the seven system variable symbols.

## G.1. \&SYSECT

\&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 is not affected by CSECT or DSECT directives or inner macro instructions occuring in that macro definition.

## G.2. \&SYSLIST

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 wiring 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:
\& $\mathrm{A}, \& \mathrm{~B}, \& \mathrm{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 $\& S Y S L I S T(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.

## G.3. \&SYSNDX

The assembler maintains a counter that is incremented by 1 each time the assembler encountered 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.

## G.4. \&SYSDATE

\&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 listed as a character string representing the month, day, and year ( $\mathrm{mm} / \mathrm{dd} / \mathrm{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.

LABEL $\triangle O P E R A T I O N \triangle$ OPERAND
1016

|  | - |  |
| :---: | :---: | :---: |
|  | - |  |
| ASMDATE | DC | C'ESYSDATE' |

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.
$\begin{array}{llll}\text { LABEL } & \triangle O P E R A T I O N A & \text { OPERAND } \\ 1 & 10 & 16 & \end{array}$


When this line of source code is executed, the assembly date is moved into a main storage area called BUF.

## G.5. \&SYSTIME

\&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 time 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,
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.


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.

```
MVC BUF,=C'ESYSTIME'
```

When this line of source code is executed, the assembly time is moved into a main storage area called BUF.

## G.6. \&SYSJDATE

\&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 (mmddyiji) 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.

| LABEL | OOPERATION $\triangle$ | OPERAND |
| :--- | :--- | :--- |

JULDATE $\quad \stackrel{\bullet}{D C} \quad$ C'ESYSJDATE'

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.

```
•
    -
    MVC BUF,=C'&SYSJDATE'
```

When this line of source code is executed, the Julian date is moved into a main storage area called BUF.

## G.7. \&SYSPARM

\&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 as follows:

| LABEL | $\triangle$ OPERATION $\triangle$ | OPERAND |
| :---: | :---: | :---: |
| $/ / \triangle$ PARAM $\triangle$ | SYSPARM $=$ ''string' $^{\prime}$ |  |

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 reference 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.

| LABEL | $\triangle$ OPERATION |  |
| :--- | :---: | :--- |
| 1 | 10 | 16 |
| OPERAND |  |  |

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.

IVC BUF, $=C^{\prime} \varepsilon S Y S P A R M '$

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.

## Index

| Term | Reference | Page | Term | Reference | Page |
| :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  | Add immediate (Al) instruction | See AI instruction. |  |
| A instruction | 102 | 10-8 | Add logical (AL) instruction | See AL |  |
| formats | 10.2 | $\begin{aligned} & 10-8 \\ & 10-7 \end{aligned}$ |  | instruction. |  |
| function | 10.2 | 10-7 |  |  |  |
| operational considerations | 10.2 | 10-7 | Add logical (ALR) instruction | See ALR instruction. |  |
| A, type constant | 5.2.9 | 5-13 | Add normalized, long format (AD) instruction | See AD |  |
| Absolute expression |  |  |  |  |  |
| definition | 4.4.1 | 4-16 | Add normalized, long format (ADR) |  |  |
| examples | 4.4.1 | 4-16 | instruction |  |  |
| relocatable terms | 4.4.1 | 4-16 |  | instruction. |  |
| Absolute term |  |  |  |  |  |
| examples | 4.4.1 | 4-16 | instruction |  |  |
| expression | 4.4 | 4-15 |  | instruction. |  |
| relocatable expression | 4.4.2 | 4-17 |  |  |  |
| ACTR statement format |  |  | Add normalized, short format (AER) instruction | See AER |  |
|  | 27.4.3 | 27-22 |  | instruction. |  |
| AD instruction |  |  | Add unnormalized, long format (AW) instruction | See AW |  |
| example | 11.2 | 11-5 |  | instruction. |  |
| formats | 11.2 | 11-3 |  |  |  |
| function | 11.2 | 11-3 |  |  |  |
| operational considerations | 11.2 | 11-4 | Add unnormalized, long format (AWR) instruction | See AWR |  |
| Add (A) instruction | See A |  |  | instruction. |  |
|  | instruction. |  | Add unnormalized, short format (AU) |  |  |
| Add (AR) instruction | See AR instruction. |  | instruction | See AU instruction. |  |
| Add decimal (AP) instruction | See AP instruction. |  | Add unnormalized, short format (AUR) instruction | See AUR instruction. |  |
| Add half word (AH) instruction | See AH instruction. |  |  |  |  |


| Term | Reference | Page | Term | Reference | Page |
| :---: | :---: | :---: | :---: | :---: | :---: |
| Address constants |  |  | AL instruction |  |  |
| A-type | 5.2.9 | 5-13 | example | 14.3.1 | 14-35 |
| external | 5.2.11 | 5-14 | formats | 14.3.1 | 14-34 |
| full-word | 5.2.9 | 5-13 | function | 14.3.1 | 14-34 |
| half-word | 5.2.8 | 5-12 | operational considerations | 14.3.1 | 14-35 |
| V-type | 5.2.11 | 5-14 |  |  |  |
| Y-type | 5.2.8 | 5-12 | Alphabetic instruction listing | Table E-2 | E-5 |
| Addressing |  |  | ALR instruction |  |  |
| main computer storage | 3.1 | 3-1 | example | 14.3.2 | 14-38 |
| register | 3.2 | 3-3 | formats | 14.3.2 | 14-37 |
|  |  |  | function | 14.3.2 | 14-37 |
| ADR instruction |  |  | operational considerations | 14.3.2 | 14-37 |
| example | 11.3 | 11-7 |  |  |  |
| formats | 11.3 | 11-6 | American Standard Code for Information |  |  |
| function | 11.3 | 11-6 | Interchange (ASCII) character codes | Table B-1 | B-1 |
| operational considerations | 11.3 | 11-6 |  |  |  |
|  |  |  | Ampersand |  |  |
| Advance listing (EJECT) direction |  |  | character string | 4.4.6 | 4-18 |
| \&SYSLIST | See EJECT directive. |  | set symbols | 27.1 | 27-2 |
|  |  |  | \&SYSDATE | G. 4 | G-2 |
| AE instruction |  |  |  |  |  |
| example | 11.4 | 11-11 | \&SYSECT | G. 1 | G-1 |
| formats | 11.4 | 11-9 |  |  |  |
| function | 11.4 | 11-9 | \&SYSLIST |  |  |
| operational considerations | 11.4 | 11-10 | example | G. 2 | G-1 |
|  |  |  | mixed mode | G. 2 | G-2 |
| AER instruction |  |  | null character string | G. 2 | G-2 |
| example | 11.5 | 11-13 |  |  |  |
| formats | 11.5 | 11-12 | \&SYSNDX | G. 3 | G-2 |
| function | 11.5 | 11-12 |  |  |  |
| operational considerations | 11.5 | 11-12 | \&SYSPARM | G. 7 | G-4 |
| AGO statement |  |  | \&SYSTIME | G. 5 | G-3 |
| format | 27.2.2 | 27-15 |  |  |  |
| function | 27.2.2 | 27-15 | And (N) instruction | See $N$ instruction |  |
| AH instruction $\quad$ a |  |  |  |  |  |
| example | 10.4 | 10-12 | And (NC) instruction | See NC |  |
| formats | 10.4 | 10-11 |  | instruction. |  |
| function | 10.4 | 10-11 |  |  |  |
| operational considerations | 10.4 | 10-11 | And (NI) instruction | See NI instruction. |  |
| Al instruction |  |  |  |  |  |
| examples | 10.5 | 10-14 | And (NR) instruction | See NR |  |
| formats | 10.5 | 10-13 |  | instruction. |  |
| function | 10.5 | 10-13 |  |  |  |
| operational considerations | 10.5 | 10-13 | ANOP statement |  |  |
|  |  |  | example | 27.2.4 | 27-18 |
| AlF statement |  |  | format | 27.2.4 | 27-17 |
| examples | 27.2.3 | 27-17 | function | 27.2.4 | 27-17 |
| format | 27.2.3 | 27-16 |  |  |  |
| function | 27.2.3 | 27-16 |  |  |  |


| Term | Reference | Page | Term | Reference | Page |
| :---: | :---: | :---: | :---: | :---: | :---: |
| AP instruction |  |  | Assembler coding form |  |  |
| examples | 9.3 | 9-8 | additional coding rules | 1.1.7 | 1-10 |
| formats | 9.3 | 9-8 | column 72 | 1.1.6 | 1-10 |
| function | 9.3 | 9-8 | comments field | 1.1.4 | 1-8 |
| operational considerations | 9.3 | 9-8 | continuation field description | 1.1.2 | 1-6 |
|  |  |  |  | 1.1 | 1-1 |
| Apostrophe, character representation | 4.4.6 | 4-18 | example | 1.1 | 1-2 |
|  |  |  |  | Fig. 1-5 | 1-11 |
| Application instructions |  |  | label field operand field | 1.1.3 | 1-6 |
| explicit length | 7.1 | 7-4 |  | 1.1.2 | 1-5 |
| formats | Fig. 7-1 | 7-2 | operation field | 1.1.1 | 1-4 |
| implicit length | 7.1 | 7-4 | sample | Fig. 1-3 | 1-3 |
| types | 7.1 | 7-1 | sequence field | 1.1.5 | 1-9 |
| AR instruction |  |  | Assembler control directives |  |  |
| example | 10.3 | 10-9 | basic functions | Table 17-1 | 17-1 |
| format | 10.3 | 10-9 | condition no operation (CNOP) | 17.1 | 17-2 |
| function | 10.3 | 10-9 | generate literal pool (LTORG) | 17.3 | 17-5 |
| operational considerations | 10.3 | 10-9 | program card (END) | 17.2 | 17-4 |
|  |  |  | program start (START) | 17.5 | 17-8 |
| Arithmetic operators |  |  | specify location counter (ORG) | 17.4 | 17-6 |
| absolute terms | 4.4.1 | 4-16 |  |  |  |
| description | 4.3.1 | 4-14 | Assembling |  |  |
|  |  |  | assemble, link-edit, and execute | 29.3 | 29-3 |
| ASCII | Table B-1 | B-1 | coding | 1.1 | 1-1 |
|  |  |  | job control procedures | 29.1 | 29-1 |
| ASM Jproc call statement |  |  |  |  |  |
| examples | 29.3.1.1 | 29-5 | Assemble listing |  |  |
| format | 29.3.1.1 | 29-4 | definition | 4.1.2 | 4-6 |
| function | 29.3.1 | 29-3 | example | 29.6 | 29-17 |
|  |  |  | organization | See organization |  |
| ASML Jproc cail statementformatfunction |  |  |  | of listing. |  |
|  | 29.3.2.1 | 29-12 | sample | Fig. 1-8 | 1-14 |
|  | 29.3.2 | 29-12 |  |  |  |
|  |  |  | Assign base register (USING) directive | See USING | rective. |
| ASMLG Jproc call statement |  |  |  |  |  |
| format | 29.3.3.1 | 29-14 | Attribute references, conditional assembly |  |  |
| function | 29.3.3 | 29-14 | applications | Table 27-3 | 27-24 |
|  |  |  | count | 27.5.5 | 27-29 |
| Assemble and link-edit |  |  | example | 27.5.6 | 27-30 |
| ASML Jproc call statement | 29.3.2.1 | 29-12 | format | 27.5 | 27-23 |
| function | 29.3.2 | 29-11 | function | 27.5 | 27-23 |
|  |  |  | integer | 27.5.4 | 27-28 |
| Assemble, link-edit, and execute |  |  | length | 27.5.2 | 27-27 |
| ASMLG jproc call statement | 29.3.3.1 | 29-14 | number | 27.5.6 | 27-30 |
|  |  |  | scale | 27.5.3 | 27-28 |
| Assembler application instruction notations |  |  |  |  |  |
|  |  |  | Attributes of symbols |  |  |
| assembled example | 4.1.1 | 4-1 | length | 4.2.3 | 4-11 |
| explicit format | 4.1.1 | 4-1 |  | 4.2.5 | 4-13 |
| implicit format | 4.1.1 | 4-2 | relocatability | 4.2.3 | 4-12 |
| machine code | 4.1.1 | 4-2 | type | Table 27-4 | 27-25 |
|  |  |  | value | 4.2.3 | 4-11 |



| Term | Reference | Page | Term | Reference | Page |
| :---: | :---: | :---: | :---: | :---: | :---: |
| Branch on count (BCTR) instruction | See BCTR instruction. |  | C |  |  |
| Branch on index high (BXH) instruction | See BXH instruction. |  | C instruction |  |  |
|  |  |  | examples | 10.6 | 10-16 |
|  |  |  | formats | 10.6 | 10-15 |
|  |  |  | function | 10.6 | 10-15 |
| Branch on index low or equal (BXLE) instruction |  |  | operational considerations | 10.6 | 10-16 |
|  | See BXLE instruction. |  | C, type constant |  |  |
|  |  |  |  | 5.2.1 | 5-8 |
| Branching |  |  | CCW instruction |  |  |
|  |  |  | examples | 21.6 | 21-9 |
| conditional branch (AIF) | 27.2.3 | 27-16 | format | 21.6 | 21-8 |
| define branch destination (ANOP) | 27.2.4 | 27-17 | function | 21.6 | 21-8 |
| function | 27.2 | 27-14 | operational considerations | 21.6 | 21-9 |
| macro definition exit (MEXIT) | 27.2.5 | 27-18 |  |  |  |
| sequence symbols | 27.2.1 | 27-14 | CD instruction |  |  |
| unconditional branch (AGO) | 27.2.2 | 27-15 | examples | 11.10 | 11-24 |
| Branching instructions |  |  | formats | 11.10 | 11-23 |
|  |  |  | function | 11.10 | 11-23 |
| BAL | 8.4 | 8-6 | operational considerations | 11.10 | 11-4 |
| BALR | 8.4 | 8-6 |  |  |  |
| BAS and BASR | 8.3 | 8-5 | CDR instruction |  |  |
| BC | 8.5 | 8-10 | examples | 11.11 | 11-26 |
| BCR | 8.5 | 8-10 | formats | 11.11 | 11-25 |
| BCT | 8.6 | 8-14 | function | 11.11 | 11-25 |
| BCTR | 8.6 | 8-14 | operational considerations | 11.11 | 11-25 |
| EX | 8.7 | 8-16 |  |  |  |
| extended mnemonic codes | 8.2 | 8-2 | CE instruction |  |  |
|  | Table 8-1 | 8-3 | examples | 11.12 | $11-28$$11-27$ |
| function | 8.1 | 8-1 | formats | 11.12 |  |
|  |  |  | function | 11.12 | 11-27 |
| BXH instructionexamples $\quad 14.1 .1$ 14-3 |  |  | operational considerations | 11.12 | 11-27 |
|  |  |  |  |  |  |  |  |
| formats | 14.1.1 | 14-2 | CER instruction |  |  |
| function | 14.1.1 | 14-2 | examples | 11.13 | 11-30 |
| BXLEinstructionformatsfunction |  |  | formats | 11.13 | 11-29 |
|  | $\begin{aligned} & 14.1 .2 \\ & 14.1 .2 \end{aligned}$ | $\begin{aligned} & 14-5 \\ & 14-5 \end{aligned}$ |  | 11.13 | 11-29 |
|  |  |  | operational considerations | 11.13 | 11-29 |
|  |  |  |  |  |  |
| $\begin{array}{ll}\text { byte } & \\ & \text { definition } \\ & \text { word structure }\end{array}$ |  |  | CH instruction |  |  |
|  | 2.1 <br> Fig. 4-2 | $\begin{aligned} & 2-1 \\ & 4-7 \end{aligned}$ | examples | 10.8 | 10-20 |
|  |  |  | formats | 10.8 | 10-19 |
|  |  |  | function | 10.8 | 10-19 |
|  |  |  | operational considerations | 10.8 | 10-20 |
|  |  |  | Channel command word (CCW) | See CCW | ruction |
|  |  |  | Character constants (C) |  |  |
|  |  |  | function | 5.2.1 | 5-8 |
|  |  |  | padding | 5.2.1 | 5-8 |
|  |  |  | truncation | 5.2.1 | 5-8 |


| Term | Reference | Page | Yerm | Reference | Page |
| :---: | :---: | :---: | :---: | :---: | :---: |
| Character conversion codes |  |  | CNOP directive |  |  |
| American Standard Code for Information |  |  | examples | 17.1 | 17-3 |
| Interchange (ASCII) | Table B-1 | B-1 | format | 17.1 | 17-2 |
|  | Table B-3 | B-3 | function | 17.1 | 17-2 |
| Extended Binary Coded Decimal |  |  |  |  |  |
| Interchange Code (EBCDIC) | Table B-2 | B-2 | Code an assembler program | 1.1 | 1-1 |
|  | Table B-3 | B-3 |  |  |  |
| punched card | Table B-3 | B-3 | Code generation, repetitive | See repetitiv |  |
|  |  |  |  | code generat |  |
| Character expression | 4.4.4 | 4-18 |  | statements. |  |
|  | 27.1.8 | 27-13 |  |  |  |
|  |  |  | CODEDIT section, listing content | 28.3 | 28-2 |
| Character representation |  |  |  | Table 28-1 | 28-2 |
| alphabetic | 2.4.1 | 2-5 |  |  |  |
| asterisk | 4.3.1 | 4-14 | COM directive |  |  |
| description | 2.4 | 2-5 | examples | 19.1 | 19-2 |
| numeric | 2.4.3 | 2-6 | format | 19.1 | 19-2 |
| special characters | 2.4.4 | 2-8 | function | 19.1 | 19-2 |
| special letters | 2.4.2 | 2-6 |  |  |  |
|  |  |  | Comments field, coding form |  |  |
| Character strings value | 4.4.6 | 4-18 | examples | 1.1.4 | 1-8 |
|  |  |  | forms | 1.1.4 | 1-8 |
| Check-off table |  |  |  |  |  |
| explanation | Appendix D |  | Comments statement | 27.3.3 | 27-20 |
| format | Appendix D |  |  |  |  |
| terms | Appendix D |  | Common storage definition (COM) |  |  |
|  |  |  | directive | See COM |  |
| CL instruction |  |  |  | directive. |  |
| examples | 12.6 | 12-15 |  |  |  |
| formats | 12.6 | 12-14 | Compare (C) instruction | See C |  |
| function | 12.6 | 12-14 |  | instruction. |  |
| operational considerations | 12.6 | 12-15 |  |  |  |
|  |  |  | Compare (CR) instruction | See CR |  |
| CLC instruction |  |  |  | instruction. |  |
| examples | 12.7 | 12-18 |  |  |  |
| formats | 12.7 | 12-17 | Compare, long format (CD) |  |  |
| function | 12.7 | 12-17 | instruction | See CD |  |
| operational considerations | 12.7 | 12-18 |  | instruction. |  |
| CLI instruction |  |  | Compare, long format (CDR) |  |  |
| examples | 12.8 | 12-21 | instruction | See CDR |  |
| formats | 12.8 | 12-20 |  | instruction. |  |
| function | 12.8 | 12-20 |  |  |  |
| operational considerations | 12.8 | 12-21 | Compare, short format (CE) |  |  |
|  |  |  | instruction | See CE |  |
| CLR instruction example | 12.9 |  |  | instruction. |  |
| formats | 12.9 | 12-25 | Compare, short format (CER) |  |  |
| function | 12.9 | 12-25 | instruction | See CER |  |
| operational considerations | 12.9 | 12-26 |  | instruction. |  |


| Term | Reference | Page |
| :---: | :---: | :---: |
| Compare decimal (CP) instruction | See CP instruction. |  |
| Compare half word (CH) instruction | See CH instruction. |  |
| Compare logical (CL) instruction | See CL instruction. |  |
| Compare logical (CLC) instruction | See CLC instruction. |  |
| Compare logical (CLI) instruction | See CLI instruction. |  |
| Compare logical (CLR) instruction | See CLR instruction. |  |
| Complex relocatable expressions definition examples restrictions | $\begin{aligned} & 4.4 .3 \\ & 4.4 .3 \\ & 4.4 .3 \end{aligned}$ | $\begin{aligned} & 4-17 \\ & 4-17 \\ & 4-17 \end{aligned}$ |
| Condition no operation (CNOP) directive | See CNOP directive. |  |
| Conditional assembly |  |  |
| attribute references | 27.5 | 27-23 |
| branching | 27.2 | 27-14 |
| error messages and comments | 27.3 | 27-18 |
| repetitive code generation | 27.4 | 27-21 |
| set symbols | 27.1 | 27-2 |
| summary | Table 27-1 | 27-1 |
| Conditional assembly control counter (ACTR) statement | See ACTR statement. |  |
| Conditional branch (AIF) statement | See AIF statement. |  |
| Continuation column, coding form | 1.1.4 | 1-8 |
| Control section identification (CSECT) directive | See CSECT directive. |  |

Reference Page

See CVB instruction.

See CVD instruction.

| COPY directive |  |  |
| :---: | :---: | :---: |
| example | 21.5 | 21-7 |
| format | 21.5 | 21-7 |
| function | 21.5 | 21-7 |
| Correction deck | F. 2 | F-5 |
| Count attributes | 27.5.5 | 27-29 |
| CP instruction |  |  |
| examples | 9.4 | 9-11 |
| formats | 9.4 | 9-10 |
| function | 9.4 | 9-10 |
| operational considerations | 9.4 | 9-11 |
| CR instruction |  |  |
| examples | 10.7 | 10-18 |
| format | 10.7 | 10-17 |
| function | 10.7 | 10-17 |
| operational considerations | 10.7 | 10-17 |
| Cross-reference section, listing content | 28.5 | 28-4 |
|  | Table 28-3 | 28-4 |


| CSECT directive |  |  |
| :--- | :--- | :--- |
| examples <br> format <br> function | 19.2 | $19-5$ |
|  | 19.2 | $19-5$ |
| CVB instruction | 19.2 | $19-5$ |
| $\quad$ examples |  |  |
| $\quad$ formats |  |  |
| $\quad$ function |  |  |
| $\quad$ operational considerations | 10.9 | $10-22$ |
|  | 10.9 | $10-21$ |
| CVD instruction | 10.9 | $10-21$ |
| $\quad$ example | 10.9 | $10-21$ |
| $\quad$ formats |  |  |
| $\quad$ function |  |  |
| $\quad$ operational considerations |  |  |
|  | 10.10 | $10-25$ |
|  | 10.10 | $10-24$ |
|  | 10.10 | $10-24$ |
|  | 10.10 | $10-25$ |


| Term | Reference | Page | Term | Reference | Page |
| :---: | :---: | :---: | :---: | :---: | :---: |
| D |  |  | Default option, example | 4.1.2 | 4-5 |
| D instruction example | 10.11 | 10-28 | Define branch destination (ANOP) statement |  |  |
| formats | 10.11 | 10-27 |  | See ANOP statement. |  |
| function | 10.11 | 10-27 |  |  |  |
| operational considerations | 10.11 | 10-28 | Define end of range (ENDO) statement | See ENDO |  |
| D, type constant | 5.2.12 | 5-15 |  | statement. |  |
| Data area program exceptions | Appendix D |  | Define start of range (DO) statement | See DO |  |
| DC statement |  |  |  | statement. |  |
| alignment | 5.1.1 | 5-4 |  |  |  |
| constant specification | 5.1.1 | 5-4 | Definition-type symbol, DC |  |  |
| definition | 5.1.1 | 5-4 | statement | 5.1.1 | 5-4 |
| example | 5.1.1 | 5-4 |  |  |  |
|  |  |  | Defirition types |  |  |
| DD instruction |  |  | A character | 5.2.9 | 5-13 |
| examples | 11.14 | 11-32 | B character | 5.2.3 | 5-9 |
| formats | 11.14 | 11-31 | C character | 5.2.1 | 5-8 |
| function | 11.14 | 11-31 | D character | 5.2.12 | 5-15 |
| operational considerations | 11.14 | 11-31 | E character | 5.2.12 | 5-15 |
|  |  |  | F character | 5.2.7 | 5-12 |
| DDR instruction |  |  | function | 5.1 | 5-1 |
| examples | 11.15 | 11-34 | H character | 5.2 .6 | 5-11 |
| formats | 11.15 | 11-33 | P character | 5.2.4 | 5-10 |
| function | 11.15 | 11-33 | S character | 5.2.10 | 5-13 |
| operational considerations | 11.15 | 11-33 | $V$ character | 5.2.11 | 5-14 |
|  |  |  | $X$ character | 5.2.2 | 5-9 |
| DE instruction |  |  | $Y$ character | 5.2.8 | 5-12 |
| examples | 11.16 | 11-36 | 2 character | 5.2.5 | 5-10 |
| formats | 11.16 | 11-35 |  |  |  |
| function | 11.16 | 11-35 | Delete operation code (OPSYM) directive |  |  |
| operational considerations | 11.16 | 11-35 |  | See OPSYM directive. |  |
| Decimal divide, program exception | Appendix D |  |  |  |  |
|  |  |  | DER instruction |  |  |
| Decimal instructions |  |  | example | 11.17 | 11-38 |
| add decimal (AP) | 9.3 | 9-8 | formats | 11.17 | 11-37 |
| compare decimal (CP) | 9.4 | 9-10 | function | 11.17 | 11-37 |
| divide decimal (DP) | 9.5 | 9-12 | operational considerations | 11.17 | 11-37 |
| move with offset (MVO) | 9.9 | 9-33 |  |  |  |
| multiply decimal (MP) | 9.11 | 9-38 | Diagnose (DIAG) instruction | 13.4.1 | 13-9 |
| pack decimal (PACK) | 9.12 | 9-40 |  |  |  |
| packed decimal manipulation | 9.1 | 9-1 | Diagnostic section, listing content | 28.6 | 28-5 |
| subtract decimal (SP) | 9.13 | 9-44 |  | Table 28-4 | 28-5 |
| unpack decimal (UNPK) | 9.14 | 9-47 |  |  |  |
| zero and add (ZAP) | 9.15 | 9-50 | Digit field | 2.4.3.1 | 2-6 |
| Decimal overflow, program exception | Appendix D |  | Digit select byte, ED instruction | 9.6.1 | 9-16 |


| Term | Reference | Page | Term | Reference | Page |
| :---: | :---: | :---: | :---: | :---: | :---: |
| Directives |  |  | DROP directive |  |  |
| base register assignment | 18.1 | 18-1 | examples | 18.1 | 18-2 |
| basic functions | Table 15-1 | 15-1 | format | 18.1 | 18-2 |
| control | 17.1 | 17-1 | function | 18.1 | 18-2 |
| input and output control | 21.1 | 21-1 |  |  |  |
| listing control | 20.1 | 20-1 | DS statement |  |  |
| program linking and sectioning | 19.1 | 19-1 | alignment | 5.1.7 | 5-8 |
|  |  |  | constant specification | 5.1.6 | 5-7 |
| Divide (D) instruction | See D |  | definition | 5.1.1 | 5-4 |
|  | instruction. |  | definition-type symbol | 5.1 .4 | 5-6 |
|  |  |  | duplication factor | 5.1.3 | 5-5 |
| Divide (DR) instruction | See DR |  | examples | 5.1.2 | 5-5 |
|  | instruction. |  | format | 5.1.1 | 5-1 |
|  |  |  | length factor ( L ) | 5.1.5 | 5-6 |
| Divide, long format (DD) |  |  |  |  |  |
| instruction | See DD |  | DSECT directive |  |  |
|  | instruction. |  | examples | 19.3 | 19-8 |
|  |  |  | format | 19.3 | 19-7 |
| Divide, long format (DDR) |  |  | function | 19.3 | 19-7 |
| instruction | See DDR |  |  |  |  |
|  | instruction. |  | Dummy control section identification |  |  |
|  |  |  | (DSECT) directive | See DSECT |  |
| Divide, short format (DE) |  |  |  | directive. |  |
| instruction | See DE instruction. |  | Duplication factor |  |  |
|  |  |  | function | 5.1.3 | 5-5 |
| Divide, short format (DER) |  |  | length attribute | 4.2.3 | 4-11 |
| instruction | See DER |  | zero examples | Table 5-2 | 5-6 |
|  | instruction. |  |  |  |  |
| Divide decimal (DP) instruction | See DP |  |  |  |  |
|  | instruction. |  |  |  |  |
|  |  |  |  |  |  |
| D0 statement |  |  |  |  |  |
| format | 27.4.1 | 27-21 | E, type constant | 5.2.12 | 5-15 |
| function | 27.4.1 | 27-21 |  |  |  |
|  |  |  | EBCDIC | Table B-2 | B-2 |
| Double word | 2.5 | 2-9 |  |  |  |
|  |  |  | ED instruction |  |  |
| DP instruction |  |  | examples | 9.6 .1 | 9-17 |
| example | 9.5 | 9-13 | formats | 9.6 | 9-15 |
| formats | 9.5 | 9-12 | function | 9.6 | 9-15 |
| function | 9.5 | 9-12 | operation summary | Table 9-1 | 9-25 |
| operational considerations | 9.5 | 9-12 | operational considerations | 9.6 | 9-15 |
| program exception | Appendix D |  |  |  |  |
|  |  |  | Edit (ED) instruction | See ED |  |
| DR instruction |  |  |  | instruction. |  |
| example | 14.2.1 | 14-8 |  |  |  |
| formats | 14.2.1 | 14-7 | Edit and mask (EDMK) |  |  |
| function | 14.2.1 | 14-7 | instruction | See EDMK |  |
| operational considerations | 14.2.1 | 14-7 |  | instruction. |  |


| Term | Reference | Page | Term | Reference | Page |
| :---: | :---: | :---: | :---: | :---: | :---: |
| EDMK instruction |  |  | Exclusive or (XI) instruction | See XI |  |
| example | 14.3.3 | 14-40 |  | instruction. |  |
| formats | 14.3.3 | 14-39 |  |  |  |
| function | 14.3.3 | 14-39 | Exclusive or (XR) instruction | See XR |  |
| operational considerations | 14.3.3 | 14-39 |  | instruction. |  |
| EJECT directive |  |  | Execute (EX) instruction | See EX |  |
| format | 20.1 | 20-2 |  | instruction. |  |
| function | 20.1 | 20-2 |  |  |  |
|  |  |  | Execution | 1.4 | 1-17 |
| Ellipsis | 4.1.2 | 4-6 |  |  |  |
|  |  |  | Explicit formats | 7.2 | 7-5 |
| END directive |  |  |  |  |  |
| examples | 17.2 | 17-4 | Explicit source code |  |  |
| format | 17.2 | 17-4 | examples | 7.2 | 7-5 |
| function | 17.2 | 17-4 | format | 7.2 | 7-5 |
| End-of-data job control statement (/*) | 29.5.1 | 29-15 | Exponent overflow, program exception | Appendix D |  |
|  |  |  | Exponent underflow |  |  |
| ENDO statement |  |  | AD instruction | 11.2 | 11-3 |
| examples | 27.4.2 | 27-22 | ADR instruction | 11.3 | 11-6 |
| format | 27.4.2 | 27-22 | AE instruction | 11.4 | 11-9 |
| function | 27.4.2 | 27-22 | AER instruction | 11.5 | 11-12 |
|  |  |  | program exception | Appendix D |  |
| ENTRY directive |  |  |  |  |  |
| example | 19.4 | 19-9 | Expressions |  |  |
| format | 19.4 | 19-9 | absolute term | 4.4 | 4-15 |
| function | 19.4 | 19-9 | character | 4.4.4 | 4-18 |
|  |  |  | complex relocatable | 4.4.3 | 4-17 |
| EQU directive |  |  | declaration | 6.2 | 6-3 |
| examples | 16.1 | 16-2 | definition | 4.4 | 4-15 |
| format | 16.1 | 16-1 | evaluation | 4.4 | 4-15 |
| function | 16.1 | 16-1 | final result | 4.4 | 4-15 |
|  |  |  | intermediate results | 4.4 | 4-15 |
| Equate (EQU) directive | See EQU |  | length attribute | 4.4.5 | 4-18 |
|  | directive. |  | relocatable term | 4.4.2 | 4-17 |
| Error messages and comments |  |  | External address constants (V) |  |  |
| MNOTE message statements | 27.3.1 | 27-19 | function | 5.2.11 | 5-14 |
| PNOTE message statements | 27.3.2 | 27-20 | padding | 5.2.11 | 5-15 |
|  |  |  | truncating | 5.2.11 | 5-15 |
| EX instruction |  |  |  |  |  |
| example | 8.7 | 8-18 | Externally defined symbol declaration (EXTRN) directive |  |  |
| formats | 8.7 | 8-16 |  | See EXTRN directive. |  |
| function | 8.7 | 8-16 |  |  |  |
| operational considerations | 8.7 | 8-18 |  |  |  |
| program exception | Appendix D |  | Externally referenced symbol declaration (ENTRY) directive |  |  |
| Exclusive or ( X ) instruction | See $X$ instruction. |  |  | See ENTRY directive. |  |
|  |  |  | EXTRN directive |  |  |
| Exclusive or ( XC ) instruction | See XC instruction. |  | examples | 19.5 | 19-10 |
|  |  |  | format | 19.5 | 19-10 |
|  |  |  | function | 19.5 | 19-10 |


| Term | Reference | Page | Term | Reference | Page |
| :---: | :---: | :---: | :---: | :---: | :---: |
| $F$ |  |  | Floating-point constants (E and D) |  |  |
| F, type constant | 5.2.7 | 5-12 | formats | 5.2.12 | 5-15 |
|  |  |  |  | Fig. 5-1 | 5-16 |
| Field separator byte, ED instruction | 9.6.1 | 9-16 | function | 5.2.12 | 5-15 |
| Fill character, ED instruction | 9.6 .1 | 9-16 | Floating point divide, program exception | Appendix D |  |
| Fixed-point divide, program exception | Appendix D |  | Floating-point instructions |  |  |
|  |  |  | add normalized, long format (AD) | 11.2 | 11-3 |
| Fixed-point instructions |  |  | add normalized, long format (ADR) | 11.3 | 11-6 |
| add (A) | 10.2 | 10-7 | add normalized, short format (AE) | 11.4 | 11-9 |
| add (AR) | 10.3 | 10-9 | add normalized, short format (AER) | 11.5 | 11-12 |
| add half word (AH) | 10.4 | 10-11 | add unnormalized, short format (AU) | 11.6 | 11-15 |
| add immediate (Al) | 10.5 | 10-13 | add unnormalized, short format (AUR) | 11.7 | 11-17 |
| compare (C) | 10.6 | 10-15 | add unnormalized, long format (AW) | 11.8 | 11-19 |
| compare (CR) | 10.7 | 10-17 | add unnormalized, long format (AWR) | 11.9 | 11-21 |
| compare half word (CH) | 10.8 | 10-19 | compare, long format (CD) | 11.10 | 11-23 |
| convert to binary (CVB) | 10.9 | 10-21 | compare, long format (CDR) | 11.11 | 11-25 |
| convert to decimal (CVD) | 10.10 | 10-24 | compare, short format (CE) | 11.12 | 11-27 |
| divide (D) | 10.11 | 10-27 | compare, short format (CER) | 11.13 | 11-29 |
| divide (DR) - featured | 14.2.1 | 14-7 | divide, long format (DD) | 11.14 | 11-31 |
| general discussion | 10.1 | 10-1 | divide, long format (DDR) | 11.15 | 11-33 |
| load (L) | 10.12 | 10-31 | divide, short format (DE) | 11.16 | 11-35 |
| load and test (LTR) | 10.14 | 10-35 | divide, short format (DER) | 11.17 | 11-37 |
| load complement (LCR) - featured | 14.2.2 | 14-9 | general description | 11.1 | 11-1 |
| load half word (LH) | 10.15 | 10-37 | halve, long format (HDR) | 11.18 | 11-39 |
| load (LR) | 10.13 | 10-33 | halve, short format (HER) | 11.19 | 11-41 |
| load multiple (LM) | 10.16 | 10-39 | load, long format (LD) | 11.22 | 11-47 |
| load negative (LNR) - teatured | 14.2.3 | 14-11 | load, long format (LDR) | 11.23 | 11-49 |
| load positive (LPR) - featured | 14.2.4 | 14-14 | load, short format (LE) | 11.24 | 11-51 |
| multiply (M) | 10.17 | 10-45 | load, short format (LER) | 11.25 | 11-53 |
| multiply half word (MH) - featured | 14.2.6 | 14-19 | load and test, long format (LTDR) | 11.30 | 11-63 |
| multiply (MR) - featured | 14.2.5 | 14-17 | load and test, short format (LTER) | 11.31 | 11-65 |
| shift left double (SLDA) - featured | 14.2.7 | 14-22 | load complement, long format (LCDR) | 11.20 | 11-43 |
| shift left single (SLA) - featured | 14.2.8 | 14-25 | load complement, short format (LCER) | 11.21 | 11-45 |
| shift right double (SRDA) - featured | 14.2.9 | 14-28 | load negative, long format (LNDR) | 11.26 | 11-55 |
| shift right single (SRA) - featured | 14.2.10 | 14-31 | load negative, short format (LNER) | 11.27 | 11-57 |
| store (ST) | 10.18 | 10-49 | load positive, long format (LPDR) | 11.28 | 11-59 |
| store half word (STH) | 10.19 | 10-51 | load positive, short format (LPER) | 11.29 | 11-61 |
| store multiple (STM) | 10.20 | 10-53 | multiply, long format (MD) | 11.32 | 11-67 |
| subtract (S) | 10.21 | 10-56 | multiply, long format (MDR) | 11.33 | 11-69 |
| subtract half word (SH) | 10.23 | 10-61 | multiply, short format (ME) | 11.34 | 11-71 |
| subtract (SR) | 10.22 | 10-58 | multiply, short format (MER) | 11.35 | 11-73 |
|  |  |  | store, long format (STD) | 11.40 | 11-83 |
| Fixed-point numbers |  |  | store, short format (STE) | 11.41 | 11-85 |
| description | 2.5 | 2-9 | subtract normalized, long format (SD) | 11.36 | 11-75 |
| formats | Fig. 2-2 | 2-9 | subtract normalized, long format (SDR) | 11.37 | 11-77 |
|  |  |  | subtract normalized, short format (SE) | 11.38 | 11-79 |
| Fixed-point overflow, program exception | Appendix A |  | subtract normalized, short format (SER) | 11.39 | 11-81 |
|  |  |  | subtract unnormalized, long format (SW) | 11.44 | 11-91 |
| Floating-point addition |  |  | subtract unnormalized, long format (SWR) | 11.45 | 11-93 |
| AD instruction | 11.2 | 11-3 | subtract unnormalized, short format (SU) | 11.42 | 11-87 |
| ADR instruction | 11.3 | 11-6 | subtract unnormalized, short format (SUR) | 11.43 | 11-89 |
| AE instruction | 11.4 | 11-9 |  |  |  |
| AER instruction | 11.5 | 11-12 |  |  |  |


| Term | Reference | Page | Term | Reference | Page |
| :---: | :---: | :---: | :---: | :---: | :---: |
| Floating-point numbers description | 2.6 | 2-9 | Halve, short format (HER) instruction | See HER instruction. |  |
| format | 2.6 | 2-9 |  |  |  |
|  |  |  | HDR instruction |  |  |
| Full word | 2.1 | 2-1 | example | 11.18 | 11-40 |
|  |  |  | formats | 11.18 | 11-39 |
| Full-word address constants (A) |  |  | function | 11.18 | 11-39 |
| function | 5.2.9 | 5-13 | operational considerations | 11.18 | 11-39 |
| padding | 5.2.9 | 5-13 |  |  |  |
| truncating | 5.2.9 | 5-13 | HER instruction |  |  |
|  |  |  | example | 11.19 | 11-42 |
| Full-word fixed-point constants (F) |  |  | formats | 11.19 | 11-41 |
| function | 5.2.7 | 5-12 | function | 11.19 | 11-41 |
| padding | 5.2 .7 | 5-12 | operational considerations | 11.19 | 11-41 |
| truncating | 5.2.7 | 5-12 |  |  |  |
|  |  |  | Hexadecimal constant ( X ) |  |  |
|  |  |  | function | 5.2.2 | 5-9 |
| G |  |  | padding | 5.2.2 | 5-9 |
| G |  |  | truncating | 5.2.2 | 5-9 |
| General register privileged instructions | 13.6 | 13-13 | Hexadecimal-decimal integer conversion | C. 1 | C-1 |
| General registers | 3.2 | 3-3 | Hexadecimal fractions (approximate values) | C. 2 | C-7 |
| Generate literal pool (LTORG) directive | See LTORG |  | Hexadecimal representation description | 23 |  |
|  | directive. |  | notation | Table 2-2 | 2-4 |
| Giobal set symbols <br> examples |  |  | HPR instruction | 13.2.1 | 13-2 |
| format | 27.1.2 | $\begin{aligned} & 21-5 \\ & 27-4 \end{aligned}$ |  |  |  |
| function | 27.1.2 | 27-4 |  |  |  |
| H |  |  | I |  |  |
|  |  |  | ICTL directive |  |  |
| H, type constant | 5.2.6 | 5-11 | examples | 21.1 | 21-2 |
|  |  |  | format | 21.1 | 21-2 |
| Half word | 2.1 | 2-1 | function | 21.1 | 21-2 |
| Half-word address constants ( Y ) |  |  | Implicit format |  |  |
| function | 5.2.8 | 5-12 | coding | 7.3 | 7-6 |
| padding | 5.2.8 | 5-12 | examples | 7.3 | 7-6 |
| truncating | 5.2.8 | 5-12 |  |  |  |
|  |  |  | Implicit source code |  |  |
| Half-word fixed-point constants (H) |  |  | examples | 7.1 | 7-4 |
| function | 5.2 .6 | 5-11 |  | 7.3 | 7-6 |
| padding | 5.2.6 | 5-11 | format | 7.3 | 7-6 |
| truncating | 5.2.6 | 5-11 |  |  |  |
| Halve, long format (HDR) instruction | See HDR instruction. |  | Include code from a library (COPY) directive | See COPY directive. |  |


| Term | Reference | Page | Term | Reference | Page |
| :---: | :---: | :---: | :---: | :---: | :---: |
| Inline expansion code |  |  | ISK instruction | 13.2.2 | 13-3 |
| BLANK macro | 30.3 | 30-4 |  |  |  |
| function | 22.1 | 22-1 | ISEQ directive |  |  |
| generation | 23.1 | 23-1 | example | 21.2 | 21-4 |
| variable | 23.1 | 23-2 | format | 21.2 | 21-4 |
|  | 30.3 | 30-4 | function | 21.2 | 21-4 |
| Input and output control directives |  |  | Integer attributes |  |  |
| basic functions | Table 21-1 | 21-1 | examples | 27.5.4 | 27-28 |
| include code from a library (COPY) | 21.5 | 21-7 | function | 27.5.4 | 27-28 |
| input format control (ICTL) | 21.1 | 21-2 |  |  |  |
| input sequence control (ISEQ) | 21.2 | 21-4 | Italics | 4.1.2 | 4-6 |
| produce a record (PUNCH) | 21.4 | 21-6 |  |  |  |
| reproduce following record (REPRO) | 21.3 | 21-5 |  |  |  |
| Input format control (ICTL directive) | See ICTL directive. |  |  |  |  |
| Input sequence control (ISEQ) directive | See ISEQ directive. |  |  |  |  |
| Insert character (IC) instruction |  |  |  |  |  |
| examples | 12.14 | 12-40 | Job control cards |  |  |
| formats | 12.14 | 12-39 | end-of-data job control statement |  |  |
| function | 12.14 | 12-39 | (/*) | 29.5.1 | 29-15 |
| operational considerations | 12.14 | 12-39 | end-of-job control statement (/\&) terminate-the-card-reader job | 29.5.2 | 29-16 |
| Insert storage key (ISK) instruction | 13.2.2 | 13-3 | control statement (//FIN) | 29.5.3 | 29-16 |
| Instruction |  |  | Job control procedures |  |  |
| aligning | 7.1 | 7-3 | running an assembler program | 29.1 | 29-1 |
| application | 7.1 | 7-1 | source deck introduction | 29.2 | 29-1 |
| branching | 8.1 | 8-1 |  |  |  |
| decimal | 9.1 | 9-1 | JOB control statement |  |  |
| definition | 7.4 | 7-6 | format | 29.2.1 | 29-2 |
| featured | 14.1 | 14-1 | function | 29.2.1 | 29-2 |
| fixed-point | 10.1 | 10-1 |  |  |  |
| floating-point | 11.1 | 11-1 |  |  |  |
| logical | 12.1 | 12-1 |  |  |  |
| privileged | 13.1 | 13-1 |  |  |  |
| RR | 7.1 | 7-3 |  |  |  |
| RS | 7.1 | 7-3 |  |  |  |
| RX | 7.1 | 7-3 |  |  |  |
| SI | 7.1 | 7-3 |  |  |  |
| SS | 7.1 | 7-3 |  |  |  |
| status switching | 13.1 | 13-1 | K |  |  |
| Instruction listings |  |  | Keyword parameters |  |  |
| alphabetic | Table E-2 | E-5 | coding | 4.1.2 | 4-4 |
| machine code | Table E-3 | E-10 | referencing in the call | 25.3 | 25-4 |
| mnemonics | Table E-1 | E-1 |  | 26.3 | 26-4 |



| Term | Reference | Page | Term | Reference | Page |
| :---: | :---: | :---: | :---: | :---: | :---: |
| Listing title declaration (TITLE) directive | See TITLE directive. |  | Load address (LA) instruction | See LA instruction. |  |
| Literals |  |  | Load and test, long format (LTDR) instruction | See LTDR instruction. |  |
| defined | 4.2 | 4-8 |  |  |  |
|  | 4.2.2 | 4-10 | Load and test (LTR) instruction | See LTR |  |
|  | 5.3 | 5-18 |  | instruction. |  |
| examples | 5.3 | 5-19 |  |  |  |
| restrictions | 5.3 | 5-18 | Load and test, short format (LTER) |  |  |
| source code | 4.2.2 | 4-10 | instruction | See LTER |  |
| specification | 4.2.2 | 4-10 |  | instruction. |  |
| LM instruction |  |  | Load complement, long format (LCDR) |  |  |
| examples | 10.16 | 10-40 | instruction | See LCDR |  |
| formats | 10.16 | 10-39 |  | instruction. |  |
| function | 10.16 | 10-39 |  |  |  |
| operational considerations | 10.16 | 10-40 | Load complement, short format (LCER) instruction | See LCER |  |
| LNDR instruction |  |  |  | instruction. |  |
| example | 11.26 | 11-56 |  |  |  |
| formats | 11.26 | 11-55 | Load complement (LCR) instruction |  |  |
| function | 11.26 | 11-55 | - featured | See LCR |  |
| operational considerations | 11.26 | 11-55 |  | instruction. |  |
| LNER instruction |  |  | Load control storage (LCS) instruction | 13.2.3 | 13-4 |
| example | 11.27 | 11-58 |  |  |  |
| formats | 11.27 | 11-57 | Load half word (LH) instruction | See LH |  |
| function | 11.27 | 11-57 |  | instruction. |  |
| operational considerations | 11.27 | 11-57 |  |  |  |
|  |  |  | Load module, creating | 1.3 | 1-16 |
| LNR instruction |  |  |  |  |  |
| example | 14.2.3 | 14-12 | Load multiple (LM) instruction | See LM |  |
| format | 14.2.3 | 14-11 |  | instruction. |  |
| function | 14.2.3 | 14-11 |  |  |  |
| operational considerations | 14.2.3 | 14-11 | Load negative, long format (LNDR) instruction | See LNDR |  |
| Load (L) instruction | See L instruction. |  |  | instruction. |  |
| Load (LR) instruction | See LR instruction. |  | Load negative, short format (LNER) instruction | See LNER instruction. |  |
| Load, long format (LD) instruction | See LD instruction. |  | Load negative (LNR) instruction | See LNR instruction. |  |
| Load, long format (LDR) instruction | See LDR instruction. |  | Load positive (LPR) instruction | See LPR instruction. |  |
| Load, short format (LE) instruction | See LE instruction. |  | Load positive, long format (LPDR) instruction | See LPDR instruction. |  |
| Load, short format (LER) instruction | See LER instruction. |  | Load positive, short format (LPER) instruction | See LPER instruction. |  |


| Term | Reference | Page | Term | Reference | Page |
| :---: | :---: | :---: | :---: | :---: | :---: |
| Load program status word (LPSW) instruction | 13.2.4 | 13-5 | Logical operators | 4.3.2 | 4-14 |
| Local set symbol |  |  | Low order | 4.1.2 | 4-8 |
| examples | 27.1.1 | 27-4 |  |  |  |
| format | 27.1.1 | 27-3 | Lowercase letters and terms, coding | 4.1.2 | 4-6 |
| function | 27.1.1 | 27-3 |  |  |  |
|  |  |  | LPDR instruction |  |  |
| Location counter |  |  | example | 11.28 | 11-60 |
| adding 1 | 4.2.4 | 4-12 | formats | 11.28 | 11-59 |
| asterisk | 4.2.4 | 4-12 | function | 11.28 | 11-59 |
| definition | 4.2.4 | 4-12 | operational considerations | 11.28 | 11-59 |
| restrictions | 4.2.4 | 4-12 |  |  |  |
| values | 4.2 | 4-8 | LPER instruction |  |  |
|  |  |  | example | 11.29 | 11-62 |
| Logical instructions |  |  | formats | 11.29 | 11-61 |
| add logical (AL) - featured | 14.3.1 | 14-34 | function | 11.29 | 11-61 |
| add logical (ALR) - featured | 14.3.2 | 14-37 | operational considerations | 11.29 | 11-61 |
| and ( N ) | 12.2 | 12-2 |  |  |  |
| and (NC) | 12.3 | 12-5 | LPR instruction |  |  |
| and (N) | 12.4 | 12-8 | example | 14.3.4 | 14-15 |
| and (NR) | 12.5 | 12-11 | format | 14.3.4 | 14-14 |
| compare logical (CL) | 12.6 | 12-14 | function | 14.3.4 | 14-14 |
| compare logical (CLC) | 12.7 | 12-17 | operational considerations | 14.3.4 | 14-14 |
| compare logical (CLI) | 12.8 | 12-20 |  |  |  |
| compare logical (CLR) | 12.9 | 12-25 | LPSW instruction | 13.2.4 | 13-5 |
| edit (ED) | 9.6 | 9-15 |  |  |  |
| edit and mark (EDMK) - feature | 14.3.3 | 14-39 | LR instruction |  |  |
| exclusive or ( X ) | 12.10 | 12-27 | example | 10.13 | 10-34 |
| exclusive or (XC) | 12.11 | 12-30 | format | 10.13 | 10-33 |
| exclusive or (XI) | 12.12 | 12-33 | function | 10.13 | 10-33 |
| exclusive or (XR) | 12.13 | 12-36 | operational considerations | 10.13 | 10-33 |
| general description | 12.1 | 12-1 |  |  |  |
| insert character (IC) | 12.14 | 12-39 | LSB | 2.1 | 2-1 |
| load address (LA) | 12.15 | 12-41 |  | 4.1.2 | 4-7 |
| move character (MVC) | 9.7 | 9-26 |  |  |  |
| move immediate (MVI) | 12.16 | 12-43 | LTDR instruction |  |  |
| move numerics (MVN) | 9.8 | 9-30 | example | 11.30 | 11-64 |
| move zones (MVZ) | 9.10 | 9-36 | formats | 11.30 | 11-63 |
| or (0) | 12.17 | 12-45 | function | 11.30 | 11-63 |
| or (OC) | 12.18 | 12-48 | operational considerations | 11.30 | 11-63 |
| or (O1) | 12.19 | 12-51 |  |  |  |
| or (OR) | 12.20 | 12-54 | LTER instruction |  |  |
| shift left double logical (SLDL) |  |  | example | 11.31 | 11-66 |
| - featured | 14.3.4 | 14-42 | formats | 11.31 | 11-65 |
| shift left single logical (SLL) | 12.21 | 12-57 | function | 11.31 | 11-65 |
| shift right double logical (SRDL) |  |  | operational considerations | 11.31 | 11-65 |
| - featured | 14.3.5 | 14-45 |  |  |  |
| shift right single logical (SRL) | 12.22 | 12-60 | LTORG directive |  |  |
| store character (STC) | 12.23 | 12-62 | format | 17.3 | 17-5 |
| subtract logical (SL) - featured | 14.3.6 | 14-48 | function | 17.3 | 17-5 |
| subtract logical (SLR) - featured | 14.3.7 | 14-51 |  |  |  |
| test under mask (TM) | 12.24 | 12-64 | LTR instruction |  |  |
| translate (TR) | 12.25 | 12-67 | example | 10.14 | 10-36 |
| translate and test (TRT) | 12.26 | 12-70 | format | 10.14 | 10-35 |
|  |  |  | function | 10.14 | 10-35 |
|  |  |  | operational considerations | 10.14 | 10-35 |


| Term | Reference | Page |
| :---: | :---: | :---: |
| M |  |  |
| M instruction |  |  |
| example | 10.17 | 10-46 |
| formats | 10.17 | 10-45 |
| function | 10.17 | 10-45 |
| operational considerations | 10.17 | 10-46 |
| Machine code |  |  |
| assembler format relationships | Fig. 4-1 | 4-5 |
| definition | 4.1.1 | 4-3 |
| instruction listing | Table E-3 | E-10 |
| purpose | 1.2 | 1-15 |
| Macro call instruction |  |  |
| call-names | 23.3 | 23-7 |
| format | 23.3 | 23-6 |
| functions | 22.2 | 22-3 |
|  | 23.3 | 23-6 |
| keyword parameter | 23.3 | 23-8 |
| parameter-list | 23.3 | 23-7 |
| positional parameter | 23.3 | 23-8 |
| MACRO definition |  |  |
| accessing in library | Fig. 23-2 | 23-5 |
| accessing in source deck | Fig. 23-1 | 23-4 |
| body | 23.1 | 23-1 |
| call-name | 23.1 | 23-2 |
| call instruction design | 24.2 | 24-2 |
| examples | Fig. 24-4 | 24-11 |
|  | Section 30 |  |
| general | 24.1 | 24-1 |
| heading | 23.1 | 23-1 |
|  | Fig. 24-1 | 24-1 |
| macro instruction and definition, |  |  |
| operation | 23.1 | 23-1 |
| parameter substitution | 23.1 | 23-2 |
| PROC and MACRO instructions |  |  |
| compared | Fig. 24-2 | 24-6 |
| prototype statement | 24.2 | 24-2 |
| storage | 23.2 | 23-3 |
| trailer | 23.1 | 23-1 |
| variable inline expansion code | 23.1 | 23-2 |
| variable symbol | 24.2 | 24-2 |

Macro definition exit (MEXIT) statement

See MEXIT statement.

| Term | Reference | Page |
| :---: | :---: | :---: |
| Macro design |  |  |
| macro call instruction | 23.3 | 23-6 |
| macro definition | 23.1 | 23-1 |
| macro definition storage | 23.2 | 23-3 |
| Macro facility |  |  |
| processor | 22.1 | 22-1 |
| source code | 22.2 | 22-3 |
| MACRO format |  |  |
| basic design | 26.1 | 26-1 |
| label argument | 26.5 | 26-6 |
| referencing keyword parameters in the call | 26.3 | 26-4 |
| referencing positional parameters in |  |  |
| the call | 26.2 | 26-2 |
| referencing subparameters in the call | 26.4 | 26-5 |
| Macro (MACRO) definition | See MACRO definition. |  |
| Macro processor |  |  |
| function | 22.1 | 22-1 |
| inline macro expansion | Fig. 22-1 | 22-2 |
| \$Y\$MAC | 22.1 | 22-1 |
| Macro source code |  |  |
| example | 30.3 | 30-4 |
| function | 22.2 | 22-3 |
| macro facility | 22.2 | 22-3 |
| types | 22.2 | 22-3 |
| \$Y\$MAC | 22.2 | 22-3 |
| Main computer storage addressing |  |  |
| data field | 3.1.2 | 3-2 |
| instruction | 3.1.1 | 3-1 |
| symbolic | 3.1.1 | 3-1 |
| Math tables |  |  |
| hexadecimal-decimal integer conversion | C. 1 | C-1 |
| hexadecimal fractions (approximate values) | C. 2 | C-7 |
| powers of 2 | C. 3 | C-8 |
| powers of 16 | C. 4 | C-9 |
| MD instruction |  |  |
| example | 11.32 | 11-68 |
| formats | 11.32 | 11-67 |
| function | 11.32 | 11-67 |
| operational considerations | 11.32 | 11-67 |


| Term | Reference | Page | Term | Reference | Page |
| :---: | :---: | :---: | :---: | :---: | :---: |
| MDR instruction |  |  | Move zones (MVZ) instruction | See MVZ |  |
| example | 11.33 | 11-70 |  | instruction. |  |
| formats | 11.33 | 11-69 |  |  |  |
| function | 11.33 | 11-69 | MP instruction |  |  |
| operational considerations | 11.33 | 11-69 | example | 9.11 | 9-39 |
|  |  |  | formats | 9.11 | 9-38 |
| ME instruction |  |  | function | 9.11 | 9-38 |
| example | 11.34 | 11-72 | operational considerations | 9.11 | 9-39 |
| formats | 11.34 | 11-71 |  |  |  |
| function | 11.34 | 11-71 | MR instruction |  |  |
| operational considerations | 11.34 | 11-71 | example | 14.2.5 | 14-18 |
|  |  |  | format | 14.2.5 | 14-17 |
| MER instruction |  |  | function | 14.2.5 | 14-17 |
| example | 11.35 | 11-74 | operational considerations | 14.2.5 | 14-17 |
| formats | 11.35 | 11-73 |  |  |  |
| function | 11.35 | 11-73 | MSB | 2.1 | 2-1 |
| operational considerations | 11.35 | 11-73 |  | 4.1.2 | 4-8 |
| Message character, ED instruction | 9.6 .1 | 9-17 | Multiple options, coding | 4.1.2 | 4-5 |
| MEXIT statement |  |  | Multiply (M) instruction | See M |  |
| format | 27.2.5 | 27-18 |  | instruction. |  |
| function | 27.2.5 | 27-18 |  |  |  |
|  |  |  | Multiply (MR) instruction | See MR |  |
| MH instruction |  |  |  | instruction. |  |
| example | 14.2.6 | 14-21 |  |  |  |
| formats | 14.2.6 | 14-19 | Multiply, long format (MD) |  |  |
| function | 14.2.6 | 14-19 | instruction | See MD |  |
| operational considerations | 14.2.6 | 14-20 |  | instruction. |  |
| Mnemonic |  |  | Multiply, long format (MDR) |  |  |
| definition | 1.1 | 1-4 | instruction | See MDR |  |
| instruction listing | Table E-1 | E-1 |  | instruction. |  |
| operation code | 1.1.1 | 1-4 |  |  |  |
| MNOTE message statement |  |  | Multiply, short format (ME) instruction | See ME |  |
| example | 27.3.1 | 27-19 |  | instruction. |  |
| format | 27.3.1 | 27-19 |  |  |  |
| function | 27.3.1 | 27-19 | Multiply, short format (MER) |  |  |
| Most significant bit (MSB) | See MSB. |  | instruction | See MER instruction. |  |
| Move character (MVC) instruction | See MVC instruction. |  | Multiply decimal (MP) instruction |  |  |
|  |  |  |  | See MP instruction. |  |
| Move immediate (MVI) instruction | See MVI instruction. |  |  |  |  |
|  |  |  | Mutiply half word (MH) | See MH instruction. |  |
| Move numeric (MVN) instruction | See MVN instruction. |  | MVC instruction |  |  |
|  |  |  | examples | 9.7 | 9-27 |
| Move with offset (MVO) |  |  | formats | 9.7 | 9-26 |
| instruction | See MVO |  | function | 9.7 | 9-26 |
|  | instruction. |  | operational considerations | 9.7 | 9-26 |


| Term | Reference | Page |
| :--- | :--- | :--- |
|  |  |  |
| MVI instruction |  |  |
| $\quad$ examples | 12.16 | $12-44$ |
| formats | 12.16 | $12-43$ |
| $\quad$ function | 12.16 | $12-43$ |
| $\quad$ operational considerations | 12.16 | $12-43$ |
|  |  |  |
| MVN instruction |  |  |
| $\quad$ examples | 9.8 | $9-31$ |
| $\quad$ formats | 9.8 | $9-30$ |
| $\quad$ function | 9.8 | $9-30$ |
| $\quad$ operational considerations | 9.8 | $9-30$ |
|  |  |  |
| MVO instruction |  |  |
| $\quad$ examples | 9.9 | $9-34$ |
| $\quad$ formats | 9.9 | $9-33$ |
| $\quad$ function | 9.9 | $9-33$ |
| $\quad$ operational considerations | 9.9 | $9-33$ |
| MVZ instruction |  |  |
| $\quad$ examples | 9.10 | $9-37$ |
| formats | 9.10 | $9-36$ |
| function | 9.10 | $9-36$ |
| operational considerations | 9.10 | $9-36$ |

N

N instruction

| examples | 12.2 | $12-3$ |
| :--- | :--- | :--- |
| formats | 12.2 | $12-2$ |
| function | 12.2 | $12-2$ |
| operational considerations | 12.2 | $12-3$ |

NC instruction

| example | 12.3 | $12-6$ |
| :--- | :--- | :--- |
| formats | 12.3 | $12-5$ |
| function | 12.3 | $12-5$ |
| operational considerations | 12.3 | $12-6$ |

NI instruction

| examples | 12.4 | $12-9$ |
| :--- | :--- | :--- |
| formats | 12.4 | $12-8$ |
| function | 12.4 | $12-8$ |
| operational considerations | 12.4 | $12-9$ |
|  |  |  |
| alization | 11.2 | $11-3$ |
| AD instruction | 11.3 | $11-6$ |
| ADR instruction | 11.4 | $11-9$ |
| AE instruction | 11.5 | $11-12$ |


| Term | Reference | Page |
| :---: | :---: | :---: |
| NR instruction |  |  |
| example | 12.5 | 12-12 |
| formats | 12.5 | 12-11 |
| function | 12.5 | 12-11 |
| operational considerations | 12.5 | 12-12 |
| Number attributes |  |  |
| example | 27.5.6 | 27-30 |
| function | 27.5.6 | 27-30 |
| Numeric data, comparison | Table 2-1 | 2-2 |
| Numeric representation |  |  |
| packed format | 2.4.3.2 | 2-7 |
| unpacked format | 2.4.3.1 | 2-6 |
| 0 |  |  |
| 0 instruction |  |  |
| example | 12.17 | 12-46 |
| formats | 12.17 | 12-45 |
| function | 12.17 | 12-45 |
| operational considerations | 12.17 | 12-46 |
| Object code |  |  |
| example | 1.2 | 1-13 |
| format | 1.2 | 1-12 |
| Object module format | Fig. 1-9 | 1-16 |
| Object program |  |  |
| definition | 4.1.2 | 4-6 |
| general | 1.2 | 1-12 |
| OC instruction |  |  |
| example | 12.18 | 12-49 |
| formats | 12.18 | 12-48 |
| function | 12.18 | 12-48 |
| operational considerations | 12.18 | 12-49 |
| 01 instruction |  |  |
| examples | 12.19 | 12-53 |
| formats | 12.19 | 12-51 |
| function | 12.19 | 12-51 |
| operational considerations | 12.19 | 12-52 |
| Operand field, coding form | 1.1 | 1-4 |
| Operand length, ED instruction | 9.6 | 9-15 |


| Term | Reference | Page | Term | Reference | Page |
| :---: | :---: | :---: | :---: | :---: | :---: |
| Operation, program exception | Appendix D |  | P |  |  |
| Operation field, coding form | 1.1.1 | 1-4 | $P$ type constant | 5.2.4 | 5-10 |
| Operators |  |  | Pack decimal (PACK) instruction |  |  |
| arithmetic | 4.3.1 | 4-14 |  | See PACK instruction. |  |
| description | 4.3 | 4-13 |  |  |  |
| logical | 4.3.2 | 4-14 |  |  |  |
| priority | Table 27-2 | 27-8 | PACK instruction |  |  |
| relational | 4.3.3 | 4-15 | examples | 24.3 .2 | 2-7 |
| summary | Table 4-2 | 4-13 |  | 2.4.3.2 9.12 | 9-41 |
| OPSYM directive |  |  | formats | 9.12 | 9-40 |
|  |  |  | function | 9.12 | 9-40 |
| example | 16.2 | 16-3 | operational considerations | 9.12 | 9-41 |
| format | 16.2 | 16-3 | packed format conversion | 2.4.3.2 | 2-7 |
| function | 16.2 | 16-3 |  |  |  |
|  |  |  | Packed decimal constant (P) |  |  |
| OPTON job control statement | 2922 | 29-2 | function | 5.2.4 | 5-10 |
|  | 29.2.2 | 29-2 | padding | 5.2.4 | 5-10 |
| function | 29.2.2 | 29-2 | truncation | 5.2.4 | 5-10 |
| Option-specifying operands | F. 1 | F-1 | PARAM statement |  |  |
| Optional information, coding | 4.1.2 | 4-4 |  | F. 1 | F-2 |
|  |  |  | function | F. 1 | F-1 |
| OR, bit comparison | 4.3.2 | 4-14 | operational considerations | F. 1 | F-5 |
| OR instruction |  |  | PNOTE message statement |  |  |
|  |  |  | format | 27.3.2 | 27-20 |
| formats | 12.20 | 12-54 | function | 27.3.2 | 27-20 |
| function | 12.20 | 12-54 |  |  |  |
| operational considerations | 12.20 | 12-55 |  | 255 |  |
| Or (0) instruction | See 0 instruction. |  | example | 30.1 | 30-1 |
|  |  |  |  |  |  |
|  |  |  | Positional parameters |  |  |
| Or (OC) instruction | See OC instruction. |  | coding | 4.1.2 | 4-6 |
|  |  |  | comma | 4.1.2 | 4-6 |
|  |  |  | referencing in the call | 25.2 | 25-3 |
| Or (01) instruction | See 01 instruction. |  |  | 26.2 | 26-2 |
|  |  |  | Powers |  |  |
| ORG directive |  |  | of 2 | C. 3 | C-8 |
|  |  |  | of 16 | C. 4 | C-9 |
| examples | 17.4 | 17-6 |  |  |  |
| format | 17.4 | 17-6 | Preface section of listing | 28.2 | 28-1 |
| function | 17.4 | 17-6 |  |  |  |
| Organization of listing |  |  | PRINT directive |  |  |
| CODEDIT | 28.3 | 28-2 | format | 20.2 | 20-3 |
| cross-reference | 28.5 | 28-4 | examples | 20.2 | 20-4 |
| diagnostic | 28.6 | 28-5 | function | 20.2 | 20-3 |
| example | 29.6 | 29-17 | Privileged instructions, status | 13.1 | 13-1 |
| external symbol dictionary (ESD) | 28.4 | 28-3 |  | 13.1 |  |
| preface | 28.2 | 28-1 |  |  |  |
| OS/3 Assembler | 1.1 | 1-1 |  |  |  |
| Output, assembly listing | Section 28 |  |  |  |  |

## Term

PROC definition
call instruction design
examples
general
heading
MACRO and PROC instruction
compared
macro instruction and definition,
communication
variable symbol
PROC format
basic design
label argument
multiple PROC names and
positional parameter 0
referencing keyword parameters
in the call
referencing positional parameters
in the call
referencing subparameters in
the call
Procedure (PROC) definition
Produce a record (PUNCH)
directive

Program end (END) directive

## Program exceptions

addressing
data
decimal divide
decimal overflow
execute
exponent overflow
exponent underflow
fixed-point divide
fixed-point overflow
floating-point divide
operation
protection
significance
specification

| Reference | Page |
| :--- | :--- |
|  |  |
| 24.2 | $24-2$ |
| Fig. $24-4$ | $24-11$ |
| 30.2 | $30-2$ |
| 24.1 | $24-1$ |
| Fig. 24-1 | $24-2$ |
| Fig. 24-2 | $24-6$ |
| Fig. $24-3$ | $24-8$ |
| 24.2 | $24-2$ |
|  |  |
| 25.1 | $25-1$ |
| 25.6 | $25-11$ |
| 25.5 | $25-9$ |
| 25.3 | $25-4$ |
| 25.2 | $25-3$ |
| 25.4 | $25-7$ |
| See PROC |  |
| definition. |  |


| Term | Reference | Page |
| :---: | :---: | :---: |
| Program linking and sectioning directives |  |  |
| common storage definition (COM) | 19.1 | 19-2 |
| control section identification (CSECT) | 19.2 | 19-5 |
| dummy control section identification (DSECT) | 19.3 | 19-7 |
| externally defined symbol declaration (ENTRY) | 19.4 | 19-9 |
| externally referenced symbol declaration (EXTRN) | 19.5 | 19-10 |
| Program start (START) directive | See START directive. |  |
| Program status word (PSW) | See PSW. |  |
| Protection program exception | Appendix D |  |
| PSW | 8.1 | 8-1 |
| PUNCH directive |  |  |
| example | 21.4 | 21-6 |
| format | 21.4 | 21-6 |
| function | 21.4 | 21-6 |
| Punched card codes | Table B-3 | B-3 |
| Punctuation marks, coding | 4.1.2 | 4-6 |
| R |  |  |
| Reading instruction notation |  |  |
| assembler application instruction | 4.1.1 | 4-1 |
| rules and meanings | 4.1.2 | 4-4 |
| REC statement |  |  |
| format | F.2.2 | F-7 |
| function | F.2.2 | F-7 |
| operational consideration | F.2.2 | F-7 |
| Register instruction equate instruction | 6.1 | 6-2 |
| Register notations, example | 4.1.2 | 4-6 |
| Relational operators | 4.3.3 | 4-15 |
| Relative addressing, location counter | 4.2.4 | 4-12 |
| Relocatability attribute | 4.2.3 | 4-12 |


| Term | Reference | Page |
| :---: | :---: | :---: |
| Relocatable expression |  |  |
| absolute terms | 4.4.2 | 4-17 |
| definition | 4.4.2 | 4-17 |
| examples | 4.4.2 | 4-17 |
| relocatable term | 4.4.2 | 4-17 |
| requirements | 4.4.2 | 4-17 |
| Relocatable term |  |  |
| absolute expression | 4.4.1 | 4-16 |
| division | 4.4 | 4-15 |
| expression | 4.4 | 4-15 |
| multiplication | 4.4 | 4-15 |
| Repetitive code generation statements | 27.4 .3 | 27-23 |
| define end of range (ENDO) | 27.4.2 | 27-22 |
| define start of range (D0) | 27.4.1 | 27-21 |
| REPRO directive |  |  |
| example | 21.3 | 21-5 |
| format | 21.3 | 21-5 |
| function | 21.3 | 21-5 |
| Reproduce following record (REPRO) directive | See REPRO directive. |  |
| RR instruction | 7.1 | 7-1 |
| RS instruction | 7.1 | 7-1 |
| Running an assembler program |  |  |
| examples | 29.6.1 | 29-17 |
| using job control | 29.1 | 29-1 |
| RX instruction | 7.1 | 7-1 |
| S |  |  |
| S instruction |  |  |
| example | 10.21 | 10-57 |
| formats | 10.21 | 10-56 |
| function | 10.21 | 10-56 |
| operational considerations | 10.21 | 10-56 |
| S switch, ED instruction | 9.6 | 9-16 |
| S, type constant | 5.2.10 | 5-13 |
| Sample program | Appendix A |  |


| Term | Reference | Page |
| :---: | :---: | :---: |
| Scale attribute |  |  |
| example | 27.5.3 | 27-28 |
| function | 27.5.3 | 27-28 |
| SD instruction |  |  |
| example | 11.36 | 11-76 |
| formats | 11.36 | 11-75 |
| function | 11.36 | 11-75 |
| operational considerations | 11.36 | 11-76 |
| SDR instruction |  |  |
| example | 11.37 | 11-78 |
| formats | 11.37 | 11-77 |
| function | 11.37 | 11-77 |
| operational considerations | 11.37 | 11-77 |
| SDT |  |  |
| binary conversion | 4.2.1 | 4-9 |
| character | 4.2.1 | 4-10 |
| decimal | 4.2.1 | 4-9 |
| hexadecimal | 4.2.1 | 4-9 |
| meaning | 4.2 | 4-8 |
|  | 4.2.1 | 4-9 |
| negative term | 4.2.1 | 4-9 |
| use | 4.2.1 | 4-9 |
| SE instruction |  |  |
| example | 11.38 | 11-80 |
| formats | 11.38 | 11-79 |
| function | 11.38 | 11-79 |
| operational considerations | 11.38 | 11-80 |
| Self-defining terms (SDT) | See SDT. |  |
| SEQ statement |  |  |
| format | F.2.1 | F-6 |
| function | F.2.1 | F-6 |
| operational considerations | F.2.1 | F-6 |
| specifications | F.2.1 | F-6 |
| Sequence field, coding form | 1.1 | 1-8 |
| Sequence symbols | 27.2.1 | 27-14 |
| SER instruction |  |  |
| example | 11.39 | 11-82 |
| formats | 11.39 | 11-81 |
| function | 11.39 | 11-81 |
| operational considerations | 11.39 | 11-81 |
| Service timer register (STR) instruction | 13.5.1 | 13-12 |


| Term | Reference | Page |
| :---: | :---: | :---: |
| Set program mask (SPM) instruction | See SPM instruction. |  |
| SET statement |  |  |
| examples | 27.1.4 | 27-8 |
| format | 27.1.4 | 27-6 |
| function | 27.1.3 | 27-6 |
|  | 27.1.4 | 27-6 |
| operator priority | Table 27-2 | 27-8 |
| Set storage key (SSK) instruction | 13.2.5 | 13-6 |
| SET symbols |  |  |
| character expressions | 27.1.8 | 27-13 |
| function | 27.1 | 27-2 |
| global | 27.1.2 | 27-4 |
| local | 27.1.1 | 27-3 |
| SET statement | 27.1.4 | 27-6 |
| SETA statement | 27.1.5 | 27-9 |
| SETB statement | 27.1.6 | 27-10 |
| SETC statement | 27.1.7 | 27-12 |
| subscripted | 27.1.9 | 27-13 |
| value assignment | 27.1.3 | 27-6 |
| Set system mask (SSM) instruction | 13.2.6 | 13-7 |
| SETA statement |  |  |
| examples | 27.1.5 | 27-10 |
| format | 27.1.5 | 27-9 |
| function | 27.1.5 | 27-9 |
| SETB statement |  |  |
| examples | 27.1.6 | 27-12 |
| format | 27.1.6 | 27-10 |
| function | 27.1.6 | 27-10 |
| SETC statement |  |  |
| examples | 27.1.7 | 27-13 |
| format | 27.1.7 | 27-12 |
| function | 27.1.7 | 27-12 |
| Setting of UPSI byte | 29.5.4 | 29-16 |
| SH instruction |  |  |
| examples | 10.23 | 10-62 |
| formats | 10.23 | 10-61 |
| function | 10.23 | 10-61 |
| operational considerations | 10.23 | 10-62 |
| Shaded option | 4.1.2 | 4-5 |



| Term | Reference | Page | Term | Reference | Page |
| :---: | :---: | :---: | :---: | :---: | :---: |
| SL instruction |  |  | Source deck |  |  |
| example | 14.3.6 | 14-49 | definition | 4.1.2 | 4-6 |
| formats | 14.3.6 | 14-48 | job control cards | 29.5 | 29-15 |
| function | 14.3.6 | 14-48 | requesting an assembly | 29.6 | 29-17 |
| operational considerations | 14.3.6 | 14-49 |  |  |  |
|  |  |  | Source deck introduction |  |  |
| SLA instruction |  |  | JOB control statement | 29.2.1 | 29-2 |
| example | 14.2.8 | 14-27 | OPTION job control statement | 29.2.2 | 29-2 |
| formats | 14.2.8 | 14-25 |  |  |  |
| function | 14.2.8 | 14-25 | Source module correction routine |  |  |
| operational considerations | 14.2.8 | 14-26 | control statements | F. 2 | F-5 |
|  |  |  | correction deck | F. 2 | F-5 |
| SLDA instruction |  |  | REC statement | F.2.2 | F-7 |
| example | 14.2.7 | 14-24 | SEQ statement | F.2.1 | F-6 |
| formats | 14.2.7 | 14-22 | SKI statement | F.2.3 | F-7 |
| function | 14.2.7 | 14-22 |  |  |  |
| operational considerations | 14.2.7 | 14-22 | Source program |  |  |
|  |  |  | general | 1.2 | 1-12 |
| SLDLinstructionexampleformatsfunctionsoperational considerations |  |  | meaning | 4.1.2 | 4-4 |
|  | 14.3.4 | 14-43 |  |  |  |
|  | 14.3.4 | 14-42 | SP instruction |  |  |
|  | 14.3.4 | 14-42 | examples | 9.13 | 9-45 |
|  | 14.3.4 | 14-43 | formats | 9.13 | 9-44 |
|  |  |  | function | 9.13 | 9-44 |
| SLL instruction |  |  | operational considerations | 9.13 | 9-44 |
| example | 12.21 | 12-58 |  |  |  |
| formats | 12.21 | 12-57 | SPACE directive |  |  |
| function | 12.21 | 12-57 | examples | 20.3 | 20-5 |
| operational considerations | 12.21 | 12-57 | format function | 20.3 | 20-5 |
|  |  |  |  | 20.3 | 20-5 |
| SLM instruction |  |  |  |  |  |
| example | 3.6.1 | 13-13 | Special characters | 2.4.4 | 2-8 |
| format | 3.6.1 | 13-13 |  |  |  |
|  |  |  | Special letters | 2.4.2 | 2-6 |
| SLR instruction |  |  |  |  |  |
| example | 14.3.7 | 14-52 | Specification, program exceptions | Appendix D |  |
| formats | 14.3.7 | 14-51 |  |  |  |
| function | 14.3.7 | 14-51 | Specify location counter (ORG) directive |  |  |
| operational considerations | 14.3.7 | 14-51 |  | See ORG directive. |  |
| SOFTSCOPE forward scan (SSFS) instruction |  |  |  |  |  |
|  | 13.4 .2 | 13-10 | SPM instruction |  |  |
|  |  |  | example | 13.7 | 13-15 |
| SOFTSCOPE reverse scan (SSRS) instruction |  |  | formats | 13.7 | 13-15 |
|  | 13.4.3 | 13-11 | function | 13.7 | 13-15 |
|  |  |  | operational considerations | 13.7 | 13-15 |
| Source cards |  |  |  |  |  |
| definition | 4.1.2 | 4-6 | SR instruction |  |  |
| general | 1.1 | 1-1 | examples | 10.22 | 10-59 |
|  |  |  | format | 10.22 | 10-58 |
| Source codeliterals$\quad$ PROC (DO loop)$\quad$ PROC (positional parameter 0 ) |  |  | function | 10.22 | 10-58 |
|  | 4.2.2 | 4-10 | operational considerations | 10.22 | 10-58 |
|  | 30.2 | 30-2 |  |  |  |
|  | 30.1 | 30-1 | SRA instruction |  |  |
|  |  |  | examples | 14.2.10 | 14-33 |
|  |  |  | formats | 14.2.10 | 14-31 |
|  |  |  | function | 14.2.10 | 14-31 |
|  |  |  | operational considerations | 14.2.10 | 14-32 |


| Term | Reference | Page |
| :---: | :---: | :---: |
| SRDA instruction |  |  |
| examples | 14.2.9 | 14-29 |
| formats | 14.2.9 | 14-28 |
| function | 14.2.9 | 14-28 |
| operational considerations | 14.2.9 | 14-29 |
| SRDL instruction |  |  |
| example | 14.3.5 | 14-46 |
| formats | 14.3.5 | 14-45 |
| function | 14.3.5 | 14-45 |
| operational considerations | 14.3.5 | 14-46 |
| SRL instruction |  |  |
| example | 12.22 | 12-61 |
| formats | 12.22 | 12-60 |
| function | 12.22 | 12-60 |
| operational considerations | 12.22 | 12-60 |
| SS instruction | 7.1 | 7-1 |
| SSFS instruction | 13.4.2 | 13-10 |
| SSK instruction | 13.2.5 | 13-6 |
| SSM instruction | 13.2.6 | 13-7 |
| SSRS instruction | 13.4.3 | 13-11 |
| SSTM instruction |  |  |
| example | 13.6.2 | 13-14 |
| formats | 13.6.2 | 13-14 |
| ST instruction |  |  |
| example | 10.18 | 10-50 |
| formats | 10.18 | 10-49 |
| function | 10.18 | 10-49 |
| operational considerations | 10.18 | 10-49 |
| START directive |  |  |
| examples | 17.5 | 17-8 |
| format | 17.5 | 17-8 |
| function | 17.5 | 17-8 |
| Start I/0 (SIO) instruction | 13.3.1 | 13-8 |
| Start-of-data job control |  |  |
| Status switching instructions |  |  |
| general discussion | 13.1 | 13-1 |
| set program mask (SPM) | 13.7 | 13-15 |
| supervisor call (SVC) | 13.8 | 13-17 |
| test and set (TS) - featured | 13.9 | 13-19 |
| STC instruction |  |  |
| example | 12.23 | 12-63 |
| formats | 12.23 | 12-62 |
| function | 12.23 | 12-62 |
| operational considerations | 12.23 | 12-62 |


| Term | Reference | Page |
| :---: | :---: | :---: |
| STD instruction |  |  |
| example | 11.40 | 11-84 |
| formats | 11.40 | 11-83 |
| function | 11.40 | 11-83 |
| operational considerations | 11.40 | 11-83 |
| STE instruction |  |  |
| example | 11.41 | 11-86 |
| formats | 11.41 | 11-85 |
| function | 11.41 | 11-85 |
| operational consideration | 11.41 | 11-85 |
| STH instruction |  |  |
| example | 10.19 | 10-52 |
| formats | 10.19 | 10-51 |
| function | 10.19 | 10-51 |
| operational considerations | 10.19 | 10-51 |
| STM instruction |  |  |
| examples | 10.20 | 10-54 |
| formats | 10.20 | 10-53 |
| function | 10.20 | 10-53 |
| operational considerations | 10.20 | 10-54 |
| Storage, type characteristics | Table 5-1 | 5-2 |
| Store (ST) instruction | See ST instruction. |  |
| Store, long format (STD) instruction <br> See STD instruction. |  |  |
| Store, short format (STE) instruction <br> See STE instruction. |  |  |
| Store character (STC) instruction | See STC instruction. |  |
| Store half word (STH) instruction | See STH instruction |  |
| Store multiple (STM) instruction | See STM instruction. |  |
| STR instruction | 13.5.1 | 13-12 |
| SU instruction |  |  |
| example | 11.42 | 11-88 |
| formats | 11.42 | 11-87 |
| function | 11.42 | 11-87 |
| operational considerations | 11.42 | 11-87 |



| Term | Reference | Page | Term | Reference | Page |
| :---: | :---: | :---: | :---: | :---: | :---: |
| Terminate-the-card-reader job control statement (//FIN) | 29.5.3 | 29-16 | Unassign base register (DROP) directive | See DROP directive. |  |
| Terms |  |  |  |  |  |
| classes | 4.2 | 4-8 | Unconditional branch (AGO) |  |  |
| comparison | Table 4-1 | 4-9 | statement | See AGO statement. |  |
| Test and set (TS) instruction | See TS instruction. |  | Unpack decimal (UNPK) instruction | See UNPK instruction. |  |
| Test under mask (TM) instruction | See TM instruction. |  | Unpacked format, numeric representation | 2.4.3.1 | 2-6 |
| TITLE directive |  |  |  |  |  |
| examples | 20.4 | 20-6 | UNPK instruction |  |  |
| format | 20.4 | 20-6 | examples | 9.14 | 9-48 |
| function | 20.4 | 20-6 | formats | 9.14 | 9-47 |
|  |  |  | function | 9.14 | 9-47 |
| TM instruction |  |  | operational considerations | 9.14 | 9-48 |
| examples | 12.24 | 12-66 |  |  |  |
| formats | 12.24 | 12-64 | Uppercase letters and terms, |  |  |
| function | 12.24 | 12-64 | coding | 4.1.2 | 4-6 |
| operational considerations | 12.24 | 12-65 |  |  |  |
|  |  |  | UPSI byte, setting | 29.5.4 | 29-16 |
| TR instruction |  |  |  |  |  |
| example | 12.25 | 12-68 | USING directive |  |  |
| formats | 12.25 | 12-67 | examples | 18.2 | 18-4 |
| function | 12.25 | 12-67 | format | 18.2 | 18-3 |
| operational considerations | 12.25 | 12-68 | function | 18.2 | 18-3 |
| translate operation | 12.25 | 12-67 |  |  |  |
| Translate (TR) instruction | See TR instruction. |  |  |  |  |
| Translate and test (TRT) instruction <br> See TRT instruction. |  |  | V |  |  |
|  |  |  | V, type constant | 5.2.11 | 5-14 |
| TRT instruction |  |  | Value attribute | 4.2.3 | 4-11 |
| example | 12.26 | 12-72 |  |  |  |
| formats | 12.26 | 12-70 |  |  |  |
| function | 12.26 | 12-70 |  |  |  |
| operational considerations | 12.26 | 12-71 |  |  |  |
| TS instruction |  |  | W |  |  |
| examples | 13.9 | 13-19 |  |  |  |
| formats | 13.9 | 13-19 | Word structure, example | Fig. 4-2 | 4-7 |
| function | 13.9 | 13-19 |  |  |  |
| operational considerations | 13.9 | 13-19 | Writing conventions | 1.1 | 1-1 |



(Name of User)

## (Business Address)

## BUSINESS REPLY MAIL <br> 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


[^0]:    *The maximum explicit length in bytes is that total length produced by the explicit length factor times the duplication factor.

[^1]:    * Not applicable

[^2]:    CROSS-GEFERENCE
    PAGE 1

